chewy 5.1.0 → 7.2.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (234) hide show
  1. checksums.yaml +4 -4
  2. data/.github/CODEOWNERS +1 -0
  3. data/.github/ISSUE_TEMPLATE/bug_report.md +39 -0
  4. data/.github/ISSUE_TEMPLATE/feature_request.md +20 -0
  5. data/.github/PULL_REQUEST_TEMPLATE.md +16 -0
  6. data/.github/workflows/ruby.yml +73 -0
  7. data/.rubocop.yml +13 -8
  8. data/.rubocop_todo.yml +110 -22
  9. data/CHANGELOG.md +449 -347
  10. data/CODE_OF_CONDUCT.md +14 -0
  11. data/CONTRIBUTING.md +63 -0
  12. data/Gemfile +3 -7
  13. data/Guardfile +3 -1
  14. data/LICENSE.txt +1 -1
  15. data/README.md +423 -311
  16. data/chewy.gemspec +8 -10
  17. data/gemfiles/rails.5.2.activerecord.gemfile +9 -14
  18. data/gemfiles/rails.6.0.activerecord.gemfile +11 -0
  19. data/gemfiles/rails.6.1.activerecord.gemfile +13 -0
  20. data/gemfiles/rails.7.0.activerecord.gemfile +13 -0
  21. data/lib/chewy/config.rb +42 -60
  22. data/lib/chewy/errors.rb +4 -10
  23. data/lib/chewy/fields/base.rb +80 -20
  24. data/lib/chewy/fields/root.rb +7 -17
  25. data/lib/chewy/index/actions.rb +62 -35
  26. data/lib/chewy/{type → index}/adapter/active_record.rb +18 -4
  27. data/lib/chewy/{type → index}/adapter/base.rb +2 -3
  28. data/lib/chewy/{type → index}/adapter/object.rb +28 -32
  29. data/lib/chewy/{type → index}/adapter/orm.rb +26 -24
  30. data/lib/chewy/index/aliases.rb +14 -5
  31. data/lib/chewy/{type → index}/crutch.rb +5 -5
  32. data/lib/chewy/index/import/bulk_builder.rb +311 -0
  33. data/lib/chewy/{type → index}/import/bulk_request.rb +6 -7
  34. data/lib/chewy/{type → index}/import/journal_builder.rb +11 -12
  35. data/lib/chewy/{type → index}/import/routine.rb +17 -16
  36. data/lib/chewy/{type → index}/import.rb +51 -33
  37. data/lib/chewy/{type → index}/mapping.rb +32 -37
  38. data/lib/chewy/index/observe/active_record_methods.rb +87 -0
  39. data/lib/chewy/index/observe/callback.rb +34 -0
  40. data/lib/chewy/index/observe.rb +17 -0
  41. data/lib/chewy/index/specification.rb +1 -0
  42. data/lib/chewy/{type → index}/syncer.rb +61 -62
  43. data/lib/chewy/{type → index}/witchcraft.rb +15 -9
  44. data/lib/chewy/{type → index}/wrapper.rb +13 -3
  45. data/lib/chewy/index.rb +46 -96
  46. data/lib/chewy/journal.rb +25 -14
  47. data/lib/chewy/minitest/helpers.rb +86 -13
  48. data/lib/chewy/minitest/search_index_receiver.rb +22 -26
  49. data/lib/chewy/multi_search.rb +62 -0
  50. data/lib/chewy/railtie.rb +6 -20
  51. data/lib/chewy/rake_helper.rb +136 -108
  52. data/lib/chewy/rspec/build_query.rb +12 -0
  53. data/lib/chewy/rspec/helpers.rb +55 -0
  54. data/lib/chewy/rspec/update_index.rb +55 -44
  55. data/lib/chewy/rspec.rb +2 -0
  56. data/lib/chewy/runtime.rb +1 -1
  57. data/lib/chewy/search/loader.rb +19 -41
  58. data/lib/chewy/search/parameters/collapse.rb +16 -0
  59. data/lib/chewy/search/parameters/concerns/query_storage.rb +2 -2
  60. data/lib/chewy/search/parameters/ignore_unavailable.rb +27 -0
  61. data/lib/chewy/search/parameters/indices.rb +12 -57
  62. data/lib/chewy/search/parameters/none.rb +1 -3
  63. data/lib/chewy/search/parameters/order.rb +6 -19
  64. data/lib/chewy/search/parameters/source.rb +5 -1
  65. data/lib/chewy/search/parameters/track_total_hits.rb +16 -0
  66. data/lib/chewy/search/parameters.rb +7 -4
  67. data/lib/chewy/search/query_proxy.rb +9 -2
  68. data/lib/chewy/search/request.rb +180 -154
  69. data/lib/chewy/search/response.rb +5 -5
  70. data/lib/chewy/search/scoping.rb +7 -8
  71. data/lib/chewy/search/scrolling.rb +16 -13
  72. data/lib/chewy/search.rb +7 -22
  73. data/lib/chewy/stash.rb +19 -30
  74. data/lib/chewy/strategy/active_job.rb +2 -2
  75. data/lib/chewy/strategy/atomic_no_refresh.rb +18 -0
  76. data/lib/chewy/strategy/base.rb +10 -0
  77. data/lib/chewy/strategy/lazy_sidekiq.rb +64 -0
  78. data/lib/chewy/strategy/sidekiq.rb +3 -2
  79. data/lib/chewy/strategy.rb +5 -19
  80. data/lib/chewy/version.rb +1 -1
  81. data/lib/chewy.rb +36 -80
  82. data/lib/generators/chewy/install_generator.rb +1 -1
  83. data/lib/tasks/chewy.rake +26 -32
  84. data/migration_guide.md +56 -0
  85. data/spec/chewy/config_spec.rb +15 -61
  86. data/spec/chewy/fields/base_spec.rb +432 -145
  87. data/spec/chewy/fields/root_spec.rb +20 -28
  88. data/spec/chewy/fields/time_fields_spec.rb +5 -5
  89. data/spec/chewy/index/actions_spec.rb +388 -55
  90. data/spec/chewy/{type → index}/adapter/active_record_spec.rb +110 -44
  91. data/spec/chewy/{type → index}/adapter/object_spec.rb +21 -6
  92. data/spec/chewy/index/aliases_spec.rb +3 -3
  93. data/spec/chewy/index/import/bulk_builder_spec.rb +494 -0
  94. data/spec/chewy/{type → index}/import/bulk_request_spec.rb +5 -12
  95. data/spec/chewy/{type → index}/import/journal_builder_spec.rb +14 -22
  96. data/spec/chewy/{type → index}/import/routine_spec.rb +19 -19
  97. data/spec/chewy/{type → index}/import_spec.rb +149 -96
  98. data/spec/chewy/index/mapping_spec.rb +135 -0
  99. data/spec/chewy/index/observe/active_record_methods_spec.rb +68 -0
  100. data/spec/chewy/index/observe/callback_spec.rb +139 -0
  101. data/spec/chewy/index/observe_spec.rb +143 -0
  102. data/spec/chewy/index/settings_spec.rb +3 -1
  103. data/spec/chewy/index/specification_spec.rb +20 -30
  104. data/spec/chewy/{type → index}/syncer_spec.rb +14 -19
  105. data/spec/chewy/{type → index}/witchcraft_spec.rb +34 -21
  106. data/spec/chewy/index/wrapper_spec.rb +100 -0
  107. data/spec/chewy/index_spec.rb +69 -137
  108. data/spec/chewy/journal_spec.rb +46 -91
  109. data/spec/chewy/minitest/helpers_spec.rb +122 -14
  110. data/spec/chewy/minitest/search_index_receiver_spec.rb +24 -26
  111. data/spec/chewy/multi_search_spec.rb +84 -0
  112. data/spec/chewy/rake_helper_spec.rb +293 -101
  113. data/spec/chewy/rspec/build_query_spec.rb +34 -0
  114. data/spec/chewy/rspec/helpers_spec.rb +61 -0
  115. data/spec/chewy/rspec/update_index_spec.rb +106 -102
  116. data/spec/chewy/runtime_spec.rb +2 -2
  117. data/spec/chewy/search/loader_spec.rb +19 -53
  118. data/spec/chewy/search/pagination/kaminari_examples.rb +3 -5
  119. data/spec/chewy/search/pagination/kaminari_spec.rb +1 -1
  120. data/spec/chewy/search/parameters/collapse_spec.rb +5 -0
  121. data/spec/chewy/search/parameters/ignore_unavailable_spec.rb +67 -0
  122. data/spec/chewy/search/parameters/indices_spec.rb +26 -118
  123. data/spec/chewy/search/parameters/none_spec.rb +1 -1
  124. data/spec/chewy/search/parameters/order_spec.rb +18 -11
  125. data/spec/chewy/search/parameters/query_storage_examples.rb +67 -21
  126. data/spec/chewy/search/parameters/search_after_spec.rb +4 -1
  127. data/spec/chewy/search/parameters/source_spec.rb +8 -2
  128. data/spec/chewy/search/parameters/track_total_hits_spec.rb +5 -0
  129. data/spec/chewy/search/parameters_spec.rb +23 -7
  130. data/spec/chewy/search/query_proxy_spec.rb +68 -17
  131. data/spec/chewy/search/request_spec.rb +344 -149
  132. data/spec/chewy/search/response_spec.rb +35 -25
  133. data/spec/chewy/search/scrolling_spec.rb +28 -26
  134. data/spec/chewy/search_spec.rb +69 -59
  135. data/spec/chewy/stash_spec.rb +16 -26
  136. data/spec/chewy/strategy/active_job_spec.rb +23 -10
  137. data/spec/chewy/strategy/atomic_no_refresh_spec.rb +60 -0
  138. data/spec/chewy/strategy/atomic_spec.rb +9 -10
  139. data/spec/chewy/strategy/lazy_sidekiq_spec.rb +214 -0
  140. data/spec/chewy/strategy/sidekiq_spec.rb +14 -10
  141. data/spec/chewy/strategy_spec.rb +19 -15
  142. data/spec/chewy_spec.rb +17 -110
  143. data/spec/spec_helper.rb +6 -29
  144. data/spec/support/active_record.rb +43 -5
  145. metadata +102 -198
  146. data/.travis.yml +0 -45
  147. data/Appraisals +0 -81
  148. data/LEGACY_DSL.md +0 -497
  149. data/gemfiles/rails.4.0.activerecord.gemfile +0 -15
  150. data/gemfiles/rails.4.1.activerecord.gemfile +0 -15
  151. data/gemfiles/rails.4.2.activerecord.gemfile +0 -16
  152. data/gemfiles/rails.4.2.mongoid.5.2.gemfile +0 -16
  153. data/gemfiles/rails.5.0.activerecord.gemfile +0 -16
  154. data/gemfiles/rails.5.0.mongoid.6.1.gemfile +0 -16
  155. data/gemfiles/rails.5.1.activerecord.gemfile +0 -16
  156. data/gemfiles/rails.5.1.mongoid.6.3.gemfile +0 -16
  157. data/gemfiles/sequel.4.45.gemfile +0 -11
  158. data/lib/chewy/backports/deep_dup.rb +0 -46
  159. data/lib/chewy/backports/duplicable.rb +0 -91
  160. data/lib/chewy/query/compose.rb +0 -68
  161. data/lib/chewy/query/criteria.rb +0 -191
  162. data/lib/chewy/query/filters.rb +0 -244
  163. data/lib/chewy/query/loading.rb +0 -110
  164. data/lib/chewy/query/nodes/and.rb +0 -25
  165. data/lib/chewy/query/nodes/base.rb +0 -17
  166. data/lib/chewy/query/nodes/bool.rb +0 -34
  167. data/lib/chewy/query/nodes/equal.rb +0 -34
  168. data/lib/chewy/query/nodes/exists.rb +0 -20
  169. data/lib/chewy/query/nodes/expr.rb +0 -28
  170. data/lib/chewy/query/nodes/field.rb +0 -110
  171. data/lib/chewy/query/nodes/has_child.rb +0 -15
  172. data/lib/chewy/query/nodes/has_parent.rb +0 -15
  173. data/lib/chewy/query/nodes/has_relation.rb +0 -59
  174. data/lib/chewy/query/nodes/match_all.rb +0 -11
  175. data/lib/chewy/query/nodes/missing.rb +0 -20
  176. data/lib/chewy/query/nodes/not.rb +0 -25
  177. data/lib/chewy/query/nodes/or.rb +0 -25
  178. data/lib/chewy/query/nodes/prefix.rb +0 -19
  179. data/lib/chewy/query/nodes/query.rb +0 -20
  180. data/lib/chewy/query/nodes/range.rb +0 -63
  181. data/lib/chewy/query/nodes/raw.rb +0 -15
  182. data/lib/chewy/query/nodes/regexp.rb +0 -35
  183. data/lib/chewy/query/nodes/script.rb +0 -20
  184. data/lib/chewy/query/pagination.rb +0 -25
  185. data/lib/chewy/query.rb +0 -1142
  186. data/lib/chewy/search/pagination/will_paginate.rb +0 -43
  187. data/lib/chewy/search/parameters/types.rb +0 -20
  188. data/lib/chewy/strategy/resque.rb +0 -27
  189. data/lib/chewy/strategy/shoryuken.rb +0 -40
  190. data/lib/chewy/type/actions.rb +0 -43
  191. data/lib/chewy/type/adapter/mongoid.rb +0 -67
  192. data/lib/chewy/type/adapter/sequel.rb +0 -93
  193. data/lib/chewy/type/import/bulk_builder.rb +0 -122
  194. data/lib/chewy/type/observe.rb +0 -82
  195. data/lib/chewy/type.rb +0 -117
  196. data/lib/sequel/plugins/chewy_observe.rb +0 -63
  197. data/spec/chewy/query/criteria_spec.rb +0 -700
  198. data/spec/chewy/query/filters_spec.rb +0 -201
  199. data/spec/chewy/query/loading_spec.rb +0 -124
  200. data/spec/chewy/query/nodes/and_spec.rb +0 -12
  201. data/spec/chewy/query/nodes/bool_spec.rb +0 -14
  202. data/spec/chewy/query/nodes/equal_spec.rb +0 -32
  203. data/spec/chewy/query/nodes/exists_spec.rb +0 -18
  204. data/spec/chewy/query/nodes/has_child_spec.rb +0 -59
  205. data/spec/chewy/query/nodes/has_parent_spec.rb +0 -59
  206. data/spec/chewy/query/nodes/match_all_spec.rb +0 -11
  207. data/spec/chewy/query/nodes/missing_spec.rb +0 -16
  208. data/spec/chewy/query/nodes/not_spec.rb +0 -14
  209. data/spec/chewy/query/nodes/or_spec.rb +0 -12
  210. data/spec/chewy/query/nodes/prefix_spec.rb +0 -16
  211. data/spec/chewy/query/nodes/query_spec.rb +0 -12
  212. data/spec/chewy/query/nodes/range_spec.rb +0 -32
  213. data/spec/chewy/query/nodes/raw_spec.rb +0 -11
  214. data/spec/chewy/query/nodes/regexp_spec.rb +0 -43
  215. data/spec/chewy/query/nodes/script_spec.rb +0 -15
  216. data/spec/chewy/query/pagination/kaminari_spec.rb +0 -5
  217. data/spec/chewy/query/pagination/will_paginate_spec.rb +0 -5
  218. data/spec/chewy/query/pagination_spec.rb +0 -39
  219. data/spec/chewy/query_spec.rb +0 -637
  220. data/spec/chewy/search/pagination/will_paginate_examples.rb +0 -63
  221. data/spec/chewy/search/pagination/will_paginate_spec.rb +0 -23
  222. data/spec/chewy/search/parameters/types_spec.rb +0 -5
  223. data/spec/chewy/strategy/resque_spec.rb +0 -46
  224. data/spec/chewy/strategy/shoryuken_spec.rb +0 -66
  225. data/spec/chewy/type/actions_spec.rb +0 -50
  226. data/spec/chewy/type/adapter/mongoid_spec.rb +0 -372
  227. data/spec/chewy/type/adapter/sequel_spec.rb +0 -472
  228. data/spec/chewy/type/import/bulk_builder_spec.rb +0 -279
  229. data/spec/chewy/type/mapping_spec.rb +0 -173
  230. data/spec/chewy/type/observe_spec.rb +0 -137
  231. data/spec/chewy/type/wrapper_spec.rb +0 -98
  232. data/spec/chewy/type_spec.rb +0 -55
  233. data/spec/support/mongoid.rb +0 -93
  234. data/spec/support/sequel.rb +0 -80
@@ -1,7 +1,7 @@
1
- require 'chewy/type/adapter/orm'
1
+ require 'chewy/index/adapter/orm'
2
2
 
3
3
  module Chewy
4
- class Type
4
+ class Index
5
5
  module Adapter
6
6
  class ActiveRecord < Orm
7
7
  def self.accepts?(target)
@@ -22,7 +22,7 @@ module Chewy
22
22
  end
23
23
 
24
24
  def import_scope(scope, options)
25
- pluck_in_batches(scope, options.slice(:batch_size)).inject(true) do |result, ids|
25
+ pluck_in_batches(scope, **options.slice(:batch_size)).inject(true) do |result, ids|
26
26
  objects = if options[:raw_import]
27
27
  raw_default_scope_where_ids_in(ids, options[:raw_import])
28
28
  else
@@ -60,7 +60,15 @@ module Chewy
60
60
  end
61
61
 
62
62
  def pluck_in_batches(scope, fields: [], batch_size: nil, typecast: true)
63
- return enum_for(:pluck_in_batches, scope, fields: fields, batch_size: batch_size, typecast: typecast) unless block_given?
63
+ unless block_given?
64
+ return enum_for(
65
+ :pluck_in_batches,
66
+ scope,
67
+ fields: fields,
68
+ batch_size: batch_size,
69
+ typecast: typecast
70
+ )
71
+ end
64
72
 
65
73
  scope = scope.reorder(target_id.asc).limit(batch_size)
66
74
  ids = pluck(scope, fields: fields, typecast: typecast)
@@ -69,6 +77,7 @@ module Chewy
69
77
  while ids.present?
70
78
  yield ids
71
79
  break if ids.size < batch_size
80
+
72
81
  last_id = ids.last.is_a?(Array) ? ids.last.first : ids.last
73
82
  ids = pluck(scope.where(target_id.gt(last_id)), fields: fields, typecast: typecast)
74
83
  end
@@ -85,6 +94,11 @@ module Chewy
85
94
  object_class.connection.execute(sql).map(&converter)
86
95
  end
87
96
 
97
+ def raw(scope, converter)
98
+ sql = scope.to_sql
99
+ object_class.connection.execute(sql).map(&converter)
100
+ end
101
+
88
102
  def relation_class
89
103
  ::ActiveRecord::Relation
90
104
  end
@@ -1,5 +1,5 @@
1
1
  module Chewy
2
- class Type
2
+ class Index
3
3
  module Adapter
4
4
  # Basic adapter class. Contains interface, need to implement to add any classes support
5
5
  class Base
@@ -13,8 +13,7 @@ module Chewy
13
13
  true
14
14
  end
15
15
 
16
- # Camelcased name, used as type class constant name.
17
- # For returned value 'Product' will be generated class name `ProductsIndex::Product`
16
+ # Camelcased name.
18
17
  #
19
18
  def name
20
19
  raise NotImplementedError
@@ -1,7 +1,7 @@
1
- require 'chewy/type/adapter/base'
1
+ require 'chewy/index/adapter/base'
2
2
 
3
3
  module Chewy
4
- class Type
4
+ class Index
5
5
  module Adapter
6
6
  # This adapter provides an ability to import documents from any
7
7
  # source. You can actually use any class or even a symbol as
@@ -14,15 +14,15 @@ module Chewy
14
14
  # @see #import
15
15
  # @see #load
16
16
  class Object < Base
17
- # The signature of the type definition.
17
+ # The signature of the index scope definition.
18
18
  #
19
19
  # @example
20
- # define_type :geoname
21
- # define_type Geoname
22
- # define_type -> { Geoname.all_the_places }, name: 'geoname'
20
+ # index_scope :geoname
21
+ # index_scope Geoname
22
+ # index_scope -> { Geoname.all_the_places }, name: 'geoname'
23
23
  #
24
24
  # @param target [Class, Symbol, String, Proc] a source of data and everything
25
- # @option options [String, Symbol] :name redefines the inferred type name if necessary
25
+ # @option options [String, Symbol] :name redefines the inferred name if necessary
26
26
  # @option options [String, Symbol] :import_all_method redefines import method name
27
27
  # @option options [String, Symbol] :load_all_method redefines batch load method name
28
28
  # @option options [String, Symbol] :load_one_method redefines per-object load method name
@@ -31,14 +31,13 @@ module Chewy
31
31
  @options = options
32
32
  end
33
33
 
34
- # Name is used for the type class creation. Inferred from the target
35
- # by default if possible.
34
+ # Inferred from the target by default if possible.
36
35
  #
37
36
  # @example
38
- # # defines MyIndex::Geoname
39
- # define_type :geoname
40
- # # still defines MyIndex::Geoname
41
- # define_type -> { Geoname.all_the_places }, name: 'geoname'
37
+ # # defines name = Geoname
38
+ # index_scope :geoname
39
+ # # still defines name = Geoname
40
+ # index_scope -> { Geoname.all_the_places }, name: 'geoname'
42
41
  #
43
42
  # @return [String]
44
43
  def name
@@ -54,14 +53,14 @@ module Chewy
54
53
  Array.wrap(collection)
55
54
  end
56
55
 
57
- # This method is used internally by `Chewy::Type.import`.
56
+ # This method is used internally by `Chewy::Index.import`.
58
57
  #
59
58
  # The idea is that any object can be imported to ES if
60
59
  # it responds to `#to_json` method.
61
60
  #
62
61
  # If method `destroyed?` is defined for object (or, in case of hash object,
63
62
  # it has `:_destroyed` or `'_destroyed'` key) and returns `true` or object
64
- # satisfy `delete_if` type option then object will be deleted from index.
63
+ # satisfy `delete_if` option then object will be deleted from index.
65
64
  # But in order to be destroyable, objects need to respond to `id` method
66
65
  # or have an `id` key so ElasticSearch could know which one to delete.
67
66
  #
@@ -78,15 +77,15 @@ module Chewy
78
77
  # end
79
78
  # end
80
79
  #
81
- # # All the folloving variants will work:
82
- # define_type Geoname
83
- # define_type Geoname, import_all_method: 'import_all'
84
- # define_type -> { FancyGeoAPI.all_points_collection }, name: 'geoname'
80
+ # # All the following variants will work:
81
+ # index_scope Geoname
82
+ # index_scope Geoname, import_all_method: 'import_all'
83
+ # index_scope -> { FancyGeoAPI.all_points_collection }, name: 'geoname'
85
84
  #
86
85
  # @param args [Array<#to_json>]
87
86
  # @option options [Integer] :batch_size import processing batch size
88
87
  # @return [true, false]
89
- def import(*args, &block)
88
+ ruby2_keywords def import(*args, &block)
90
89
  collection, options = import_args(*args)
91
90
  import_objects(collection, options, &block)
92
91
  end
@@ -113,16 +112,15 @@ module Chewy
113
112
  # end
114
113
  # end
115
114
  #
116
- # @see Chewy::Type::Adapter::Base#import_fields
117
- def import_fields(*args)
115
+ # @see Chewy::Index::Adapter::Base#import_fields
116
+ ruby2_keywords def import_fields(*args, &block)
118
117
  return enum_for(:import_fields, *args) unless block_given?
118
+
119
119
  options = args.extract_options!
120
120
  options[:batch_size] ||= BATCH_SIZE
121
121
 
122
122
  if args.empty? && @target.respond_to?(pluck_method)
123
- @target.send(pluck_method, :id, *options[:fields]).each_slice(options[:batch_size]) do |batch|
124
- yield batch
125
- end
123
+ @target.send(pluck_method, :id, *options[:fields]).each_slice(options[:batch_size], &block)
126
124
  elsif options[:fields].blank?
127
125
  import_references(*args, options) do |batch|
128
126
  yield batch.map { |object| object_field(object, :id) || object }
@@ -140,14 +138,12 @@ module Chewy
140
138
 
141
139
  # For the Object adapter returns the objects themselves in batches.
142
140
  #
143
- # @see Chewy::Type::Adapter::Base#import_references
144
- def import_references(*args)
141
+ # @see Chewy::Index::Adapter::Base#import_references
142
+ ruby2_keywords def import_references(*args, &block)
145
143
  return enum_for(:import_references, *args) unless block_given?
146
144
 
147
145
  collection, options = import_args(*args)
148
- collection.each_slice(options[:batch_size]) do |batch|
149
- yield batch
150
- end
146
+ collection.each_slice(options[:batch_size], &block)
151
147
  end
152
148
 
153
149
  # This method is used internally by the request DSL when the
@@ -157,7 +153,7 @@ module Chewy
157
153
  #
158
154
  # If none of the `load_all_method` or `load_one_method` is implemented
159
155
  # for the target - the method will return nil. This means that the
160
- # loader will return an array `Chewy::Type` objects that actually was passed.
156
+ # loader will return an array `Chewy::Index` objects that actually was passed.
161
157
  #
162
158
  # To use loading for objects it is obviously required to provide
163
159
  # some meaningful ids for ES documents.
@@ -175,7 +171,7 @@ module Chewy
175
171
  # end
176
172
  # end
177
173
  #
178
- # MyIndex::Geoname.load(additional_data: true).objects
174
+ # MyIndex.load(additional_data: true).objects
179
175
  #
180
176
  # @param ids [Array<Hash>] an array of ids from ES hits
181
177
  # @param options [Hash] any options passed here with the request DSL `load` method.
@@ -1,7 +1,7 @@
1
- require 'chewy/type/adapter/base'
1
+ require 'chewy/index/adapter/base'
2
2
 
3
3
  module Chewy
4
- class Type
4
+ class Index
5
5
  module Adapter
6
6
  class Orm < Base
7
7
  attr_reader :default_scope
@@ -45,6 +45,7 @@ module Chewy
45
45
  # Import options:
46
46
  #
47
47
  # <tt>:batch_size</tt> - import batch size, 1000 objects by default
48
+ # <tt>:direct_import</tt> - import objects without reloading
48
49
  #
49
50
  # Method handles destroyed objects as well. In case of objects ORM scope
50
51
  # or array passed, objects, responding with true to `destroyed?` method will be deleted
@@ -53,72 +54,73 @@ module Chewy
53
54
  #
54
55
  # users = User.all
55
56
  # users.each { |user| user.destroy if user.inactive? }
56
- # UsersIndex::User.import users # inactive users will be deleted from index
57
+ # UsersIndex.import users # inactive users will be deleted from index
57
58
  # # or
58
- # UsersIndex::User.import users.map(&:id) # deleted user ids will be deleted from index
59
+ # UsersIndex.import users.map(&:id) # deleted user ids will be deleted from index
59
60
  #
60
61
  # Also there is custom type option `delete_if`. It it returns `true`
61
62
  # object will be deleted from index. Note that if this option is defined and
62
63
  # return `false` Chewy will still check `destroyed?` method. This is useful
63
64
  # for paranoid objects deleting implementation.
64
65
  #
65
- # define_type User, delete_if: ->{ deleted_at } do
66
- # ...
67
- # end
66
+ # index_scope User, delete_if: ->{ deleted_at }
67
+ # ...
68
68
  #
69
69
  # users = User.all
70
70
  # users.each { |user| user.deleted_at = Time.now }
71
- # UsersIndex::User.import users # paranoid deleted users will be deleted from index
71
+ # UsersIndex.import users # paranoid deleted users will be deleted from index
72
72
  # # or
73
- # UsersIndex::User.import users.map(&:id) # user ids will be deleted from index
73
+ # UsersIndex.import users.map(&:id) # user ids will be deleted from index
74
74
  #
75
- def import(*args, &block)
75
+ ruby2_keywords def import(*args, &block)
76
76
  collection, options = import_args(*args)
77
77
 
78
- if collection.is_a?(relation_class)
79
- import_scope(collection, options, &block)
80
- else
78
+ if !collection.is_a?(relation_class) || options[:direct_import]
81
79
  import_objects(collection, options, &block)
80
+ else
81
+ import_scope(collection, options, &block)
82
82
  end
83
83
  end
84
84
 
85
- def import_fields(*args, &block)
85
+ ruby2_keywords def import_fields(*args, &block)
86
86
  return enum_for(:import_fields, *args) unless block_given?
87
87
 
88
88
  collection, options = import_args(*args)
89
89
 
90
90
  if options[:fields].present? || collection.is_a?(relation_class)
91
91
  collection = all_scope_where_ids_in(identify(collection)) unless collection.is_a?(relation_class)
92
- pluck_in_batches(collection, options.slice(:fields, :batch_size, :typecast), &block)
92
+ pluck_in_batches(collection, **options.slice(:fields, :batch_size, :typecast), &block)
93
93
  else
94
- identify(collection).each_slice(options[:batch_size]) do |batch|
95
- yield batch
96
- end
94
+ identify(collection).each_slice(options[:batch_size], &block)
97
95
  end
98
96
  end
99
97
  alias_method :import_references, :import_fields
100
98
 
101
99
  def load(ids, **options)
102
100
  scope = all_scope_where_ids_in(ids)
103
- additional_scope = options[options[:_type].type_name.to_sym].try(:[], :scope) || options[:scope]
101
+ additional_scope = options[options[:_index].to_sym].try(:[], :scope) || options[:scope]
104
102
 
105
103
  loaded_objects = load_scope_objects(scope, additional_scope)
106
- .index_by do |object|
107
- object.public_send(primary_key).to_s
108
- end
104
+ loaded_objects = raw(loaded_objects, options[:raw_import]) if options[:raw_import]
105
+
106
+ indexed_objects = loaded_objects.index_by do |object|
107
+ object.public_send(primary_key).to_s
108
+ end
109
109
 
110
- ids.map { |id| loaded_objects[id.to_s] }
110
+ ids.map { |id| indexed_objects[id.to_s] }
111
111
  end
112
112
 
113
113
  private
114
114
 
115
115
  def import_objects(collection, options)
116
116
  collection_ids = identify(collection)
117
- hash = Hash[collection_ids.map(&:to_s).zip(collection)]
117
+ hash = collection_ids.map(&:to_s).zip(collection).to_h
118
118
 
119
119
  indexed = collection_ids.each_slice(options[:batch_size]).map do |ids|
120
120
  batch = if options[:raw_import]
121
121
  raw_default_scope_where_ids_in(ids, options[:raw_import])
122
+ elsif options[:direct_import]
123
+ hash.values_at(*ids.map(&:to_s))
122
124
  else
123
125
  default_scope_where_ids_in(ids)
124
126
  end
@@ -5,14 +5,23 @@ module Chewy
5
5
 
6
6
  module ClassMethods
7
7
  def indexes
8
- client.indices.get_alias(name: index_name).keys
9
- rescue Elasticsearch::Transport::Transport::Errors::NotFound
10
- []
8
+ indexes = empty_if_not_found { client.indices.get(index: index_name).keys }
9
+ indexes += empty_if_not_found { client.indices.get_alias(name: index_name).keys }
10
+ indexes.compact.uniq
11
11
  end
12
12
 
13
13
  def aliases
14
- name = index_name
15
- client.indices.get_alias(index: name, name: '*')[name].try(:[], 'aliases').try(:keys) || []
14
+ empty_if_not_found do
15
+ client.indices.get_alias(index: index_name, name: '*').values.flat_map do |aliases|
16
+ aliases['aliases'].keys
17
+ end
18
+ end.compact.uniq
19
+ end
20
+
21
+ private
22
+
23
+ def empty_if_not_found
24
+ yield
16
25
  rescue Elasticsearch::Transport::Transport::Errors::NotFound
17
26
  []
18
27
  end
@@ -1,5 +1,5 @@
1
1
  module Chewy
2
- class Type
2
+ class Index
3
3
  module Crutch
4
4
  extend ActiveSupport::Concern
5
5
 
@@ -9,13 +9,13 @@ module Chewy
9
9
  end
10
10
 
11
11
  class Crutches
12
- def initialize(type, collection)
13
- @type = type
12
+ def initialize(index, collection)
13
+ @index = index
14
14
  @collection = collection
15
- @type._crutches.each_key do |name|
15
+ @index._crutches.each_key do |name|
16
16
  singleton_class.class_eval <<-METHOD, __FILE__, __LINE__ + 1
17
17
  def #{name}
18
- @#{name} ||= @type._crutches[:#{name}].call @collection
18
+ @#{name} ||= @index._crutches[:#{name}].call @collection
19
19
  end
20
20
  METHOD
21
21
  end