38 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			38 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
enabled         = ENV['ES_ENABLED'] == 'true'
 | 
						|
host            = ENV.fetch('ES_HOST') { 'localhost' }
 | 
						|
port            = ENV.fetch('ES_PORT') { 9200 }
 | 
						|
user            = ENV.fetch('ES_USER') { nil }
 | 
						|
password        = ENV.fetch('ES_PASS') { nil }
 | 
						|
fallback_prefix = ENV.fetch('REDIS_NAMESPACE') { nil }
 | 
						|
prefix          = ENV.fetch('ES_PREFIX') { fallback_prefix }
 | 
						|
 | 
						|
Chewy.settings = {
 | 
						|
  host: "#{host}:#{port}",
 | 
						|
  prefix: prefix,
 | 
						|
  enabled: enabled,
 | 
						|
  journal: false,
 | 
						|
  user: user,
 | 
						|
  password: password,
 | 
						|
}
 | 
						|
 | 
						|
# We use our own async strategy even outside the request-response
 | 
						|
# cycle, which takes care of checking if Elasticsearch is enabled
 | 
						|
# or not. However, mind that for the Rails console, the :urgent
 | 
						|
# strategy is set automatically with no way to override it.
 | 
						|
Chewy.root_strategy              = :bypass_with_warning if Rails.env.production?
 | 
						|
Chewy.request_strategy           = :mastodon
 | 
						|
Chewy.use_after_commit_callbacks = false
 | 
						|
 | 
						|
module Chewy
 | 
						|
  class << self
 | 
						|
    def enabled?
 | 
						|
      settings[:enabled]
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 | 
						|
 | 
						|
# Elasticsearch uses Faraday internally. Faraday interprets the
 | 
						|
# http_proxy env variable by default which leads to issues when
 | 
						|
# Mastodon is run with hidden services enabled, because
 | 
						|
# Elasticsearch is *not* supposed to be accessed through a proxy
 | 
						|
Faraday.ignore_env_proxy = true
 |