5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
# File 'lib/searchkick/model.rb', line 5
def searchkick(options = {})
raise "Only call searchkick once per model" if respond_to?(:searchkick_index)
Searchkick.models << self
class_eval do
cattr_reader :searchkick_options, :searchkick_klass
callbacks = options.key?(:callbacks) ? options[:callbacks] : true
class_variable_set :@@searchkick_options, options.dup
class_variable_set :@@searchkick_klass, self
class_variable_set :@@searchkick_callbacks, callbacks
class_variable_set :@@searchkick_index, options[:index_name] ||
(options[:index_prefix].respond_to?(:call) && proc { [options[:index_prefix].call, model_name.plural, Searchkick.env].compact.join("_") }) ||
[options[:index_prefix], model_name.plural, Searchkick.env].compact.join("_")
class << self
def searchkick_search(term = nil, options = {}, &block)
searchkick_index.search_model(self, term, options, &block)
end
alias_method Searchkick.search_method_name, :searchkick_search if Searchkick.search_method_name
def searchkick_index
index = class_variable_get :@@searchkick_index
index = index.call if index.respond_to? :call
Searchkick::Index.new(index, searchkick_options)
end
def enable_search_callbacks
class_variable_set :@@searchkick_callbacks, true
end
def disable_search_callbacks
class_variable_set :@@searchkick_callbacks, false
end
def search_callbacks?
class_variable_get(:@@searchkick_callbacks) && Searchkick.callbacks?
end
def searchkick_reindex(options = {})
unless options[:accept_danger]
if (respond_to?(:current_scope) && respond_to?(:default_scoped) && current_scope && current_scope.to_sql != default_scoped.to_sql) ||
(respond_to?(:queryable) && queryable != unscoped.with_default_scope)
raise Searchkick::DangerousOperation, "Only call reindex on models, not relations. Pass `accept_danger: true` if this is your intention."
end
end
searchkick_index.reindex_scope(searchkick_klass, options)
end
alias_method :reindex, :searchkick_reindex unless method_defined?(:reindex)
def clean_indices
searchkick_index.clean_indices
end
def searchkick_import(options = {})
(options[:index] || searchkick_index).import_scope(searchkick_klass)
end
def searchkick_create_index
searchkick_index.create_index
end
def searchkick_index_options
searchkick_index.index_options
end
end
extend Searchkick::Reindex
callback_name = callbacks == :async ? :reindex_async : :reindex
if respond_to?(:after_commit)
after_commit callback_name, if: proc { self.class.search_callbacks? }
elsif respond_to?(:after_save)
after_save callback_name, if: proc { self.class.search_callbacks? }
after_destroy callback_name, if: proc { self.class.search_callbacks? }
end
def reindex
self.class.searchkick_index.reindex_record(self)
end unless method_defined?(:reindex)
def reindex_async
self.class.searchkick_index.reindex_record_async(self)
end unless method_defined?(:reindex_async)
def similar(options = {})
self.class.searchkick_index.similar_record(self, options)
end unless method_defined?(:similar)
def search_data
respond_to?(:to_hash) ? to_hash : serializable_hash
end unless method_defined?(:search_data)
def should_index?
true
end unless method_defined?(:should_index?)
end
end
|