|
@@ -1,10 +1,6 @@
|
|
|
# Copyright (C) 2012-2013 Zammad Foundation, http://zammad-foundation.org/
|
|
|
|
|
|
class SearchIndexBackend
|
|
|
- @@index = "zammad_#{Rails.env}"
|
|
|
- @@url = 'http://217.111.80.181'
|
|
|
- @@user = 'elasticsearch'
|
|
|
- @@pw = 'zammad'
|
|
|
|
|
|
=begin
|
|
|
|
|
@@ -16,15 +12,12 @@ add new object to search index
|
|
|
|
|
|
def self.add(type, data)
|
|
|
|
|
|
- url = "#{@@url}/#{@@index}/#{type}/#{data[:id]}"
|
|
|
+ url = build_url( type, data['id'] )
|
|
|
+ return if !url
|
|
|
|
|
|
puts "# curl -X POST \"#{url}\" -d '#{data.to_json}'"
|
|
|
|
|
|
- conn = Faraday.new( :url => url )
|
|
|
- if @@user && @@pw
|
|
|
- conn.basic_auth( @@user, @@pw )
|
|
|
- end
|
|
|
-
|
|
|
+ conn = connection( url )
|
|
|
response = conn.post do |req|
|
|
|
req.url url
|
|
|
req.headers['Content-Type'] = 'application/json'
|
|
@@ -48,19 +41,13 @@ remove whole data from index
|
|
|
=end
|
|
|
|
|
|
def self.remove( type, o_id = nil )
|
|
|
- if o_id
|
|
|
- url = "#{@@url}/#{@@index}/#{type}/#{o_id}"
|
|
|
- else
|
|
|
- url = "#{@@url}/#{@@index}/#{type}"
|
|
|
- end
|
|
|
+ url = build_url( type, o_id )
|
|
|
+ return if !url
|
|
|
|
|
|
puts "# curl -X DELETE \"#{url}\""
|
|
|
|
|
|
- conn = Faraday.new( :url => url )
|
|
|
- if @@user && @@pw
|
|
|
- conn.basic_auth( @@user, @@pw )
|
|
|
- end
|
|
|
- response = conn.delete url
|
|
|
+ conn = connection( url )
|
|
|
+ response = conn.delete( url )
|
|
|
# puts response.body.to_s
|
|
|
puts "# #{response.status.to_s}"
|
|
|
return true if response.success?
|
|
@@ -79,4 +66,27 @@ return all activity entries of an user
|
|
|
def self.search(user,limit)
|
|
|
end
|
|
|
|
|
|
+ private
|
|
|
+
|
|
|
+ def self.build_url( type, o_id = nil )
|
|
|
+ index = Setting.get('es_index') + "_#{Rails.env}"
|
|
|
+ url = Setting.get('es_url')
|
|
|
+ return if !url
|
|
|
+ if o_id
|
|
|
+ url = "#{url}/#{index}/#{type}/#{o_id}"
|
|
|
+ else
|
|
|
+ url = "#{url}/#{index}/#{type}"
|
|
|
+ end
|
|
|
+ url
|
|
|
+ end
|
|
|
+
|
|
|
+ def self.connection( url )
|
|
|
+ conn = Faraday.new( :url => url )
|
|
|
+ user = Setting.get('es_user')
|
|
|
+ pw = Setting.get('es_password')
|
|
|
+ if user && !user.empty? && pw && !pw.empty?
|
|
|
+ conn.basic_auth( user, pw )
|
|
|
+ end
|
|
|
+ conn
|
|
|
+ end
|
|
|
end
|