activerecord-filter 7.0.1 → 8.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/lib/active_record/filter/alias_tracker_extension.rb +2 -0
- data/lib/active_record/filter/filter_clause_factory.rb +4 -2
- data/lib/active_record/filter/predicate_builder_extension.rb +22 -12
- data/lib/active_record/filter/query_methods_extension.rb +4 -2
- data/lib/active_record/filter/relation_extension.rb +25 -7
- data/lib/active_record/filter/spawn_methods_extension.rb +2 -0
- data/lib/active_record/filter/unkown_filter_error.rb +2 -0
- data/lib/active_record/filter/version.rb +3 -1
- data/lib/active_record/filter.rb +2 -0
- metadata +25 -14
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 4cee15d7015346ac808e7892435628ff50b19aa86ff9a1ce671a1125d21e1ba4
|
|
4
|
+
data.tar.gz: a27330b0c68a8913f5aee1c95cacad8d9475492c5fd889ebff3b78ddb7b0a6c4
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: 5fcc52cd1ef6c55ec62ee8c2472a4cf8d39abf0e974b468020cbfacd07dc0b4af1b132da7a83994b6d014ff751eaf12b16725f790e3072df384d8f2fd4a3d898
|
|
7
|
+
data.tar.gz: 304f6d204c1d2c9359066d94e2dff95af5350fde8d1598cd61e64c8c9019dc39ac4a502d7483dff23c1cb0a35e1803597f9543434910f925310a6e9f7647eda5
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
1
3
|
require "active_support/concern"
|
|
2
4
|
|
|
3
5
|
module ActiveRecord::Filter::PredicateBuilderExtension
|
|
@@ -33,7 +35,7 @@ module ActiveRecord::Filter::PredicateBuilderExtension
|
|
|
33
35
|
relations << js
|
|
34
36
|
end
|
|
35
37
|
end
|
|
36
|
-
|
|
38
|
+
elsif reflection = klass._reflections[key.to_sym]
|
|
37
39
|
if value.is_a?(Hash)
|
|
38
40
|
relations << if reflection.polymorphic?
|
|
39
41
|
value = value.dup
|
|
@@ -65,11 +67,11 @@ module ActiveRecord::Filter::PredicateBuilderExtension
|
|
|
65
67
|
elsif value != true && value != false && value != 'true' && value != 'false' && !value.nil?
|
|
66
68
|
relations << key
|
|
67
69
|
end
|
|
68
|
-
elsif !klass.columns_hash.has_key?(key.to_s) && key.to_s.end_with?('_ids') && reflection = klass._reflections[key.to_s.gsub(/_ids$/, 's')]
|
|
70
|
+
elsif !klass.columns_hash.has_key?(key.to_s) && key.to_s.end_with?('_ids') && reflection = klass._reflections[key.to_s.gsub(/_ids$/, 's').to_sym]
|
|
69
71
|
relations << reflection.name
|
|
70
72
|
elsif reflection = klass.reflect_on_all_associations(:has_and_belongs_to_many).find {|r| r.join_table == key.to_s && value.keys.first.to_s == r.association_foreign_key.to_s }
|
|
71
|
-
reflection = klass._reflections[klass._reflections[reflection.name
|
|
72
|
-
relations << {reflection.name => build_filter_joins(reflection.klass, value)}
|
|
73
|
+
reflection = klass._reflections[klass._reflections[reflection.name].send(:delegate_reflection).options[:through]]
|
|
74
|
+
relations << { reflection.name => build_filter_joins(reflection.klass, value) }
|
|
73
75
|
else
|
|
74
76
|
{key => value}
|
|
75
77
|
end
|
|
@@ -297,32 +299,40 @@ module ActiveRecord::Filter::PredicateBuilderExtension
|
|
|
297
299
|
value = value.dup
|
|
298
300
|
klass = value.delete(:as).safe_constantize
|
|
299
301
|
|
|
300
|
-
builder =
|
|
302
|
+
builder = new_predicate_builder_extension(
|
|
301
303
|
klass,
|
|
302
304
|
alias_tracker.aliased_table_for_relation(relation_trail + ["#{klass.table_name}_as_#{relation.name}"], klass.arel_table) { klass.arel_table.name },
|
|
303
305
|
relation
|
|
304
|
-
)
|
|
306
|
+
)
|
|
305
307
|
builder.build_from_filter_hash(value, relation_trail + ["#{klass.table_name}_as_#{relation.name}"], alias_tracker)
|
|
306
308
|
else
|
|
307
|
-
builder =
|
|
309
|
+
builder = new_predicate_builder_extension(
|
|
308
310
|
relation.klass,
|
|
309
311
|
alias_tracker.aliased_table_for_relation(relation_trail + [relation.name], relation.klass.arel_table) { relation.alias_candidate(table.arel_table.name || relation.klass.arel_table) },
|
|
310
312
|
relation
|
|
311
|
-
)
|
|
313
|
+
)
|
|
312
314
|
builder.build_from_filter_hash(value, relation_trail + [relation.name], alias_tracker)
|
|
313
315
|
end
|
|
314
316
|
|
|
315
317
|
end
|
|
316
318
|
|
|
317
|
-
|
|
318
319
|
def expand_filter_for_join_table(relation, value, relation_trail, alias_tracker)
|
|
319
|
-
relation = relation.active_record._reflections[relation.active_record._reflections[relation.name
|
|
320
|
-
builder =
|
|
320
|
+
relation = relation.active_record._reflections[relation.active_record._reflections[relation.name].send(:delegate_reflection).options[:through]]
|
|
321
|
+
builder = new_predicate_builder_extension(
|
|
321
322
|
relation.klass,
|
|
322
323
|
alias_tracker.aliased_table_for_relation(relation_trail + [relation.name], relation.klass.arel_table) { relation.alias_candidate(table.arel_table.name || relation.klass.arel_table) },
|
|
323
324
|
relation
|
|
324
|
-
)
|
|
325
|
+
)
|
|
325
326
|
builder.build_from_filter_hash(value, relation_trail + [relation.name], alias_tracker)
|
|
326
327
|
end
|
|
327
328
|
|
|
329
|
+
if ActiveRecord.version >= "8.1"
|
|
330
|
+
def new_predicate_builder_extension(a,b,c)
|
|
331
|
+
self.class.new(ActiveRecord::TableMetadata.new(a, b))
|
|
332
|
+
end
|
|
333
|
+
else
|
|
334
|
+
def new_predicate_builder_extension(a,b,c)
|
|
335
|
+
self.class.new(ActiveRecord::TableMetadata.new(a, b, c))
|
|
336
|
+
end
|
|
337
|
+
end
|
|
328
338
|
end
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
1
3
|
module ActiveRecord::Filter::QueryMethodsExtension
|
|
2
4
|
private
|
|
3
5
|
def build_join_buckets
|
|
@@ -30,7 +32,7 @@ private
|
|
|
30
32
|
|
|
31
33
|
joins = joins_values.dup
|
|
32
34
|
if joins.last.is_a?(ActiveRecord::Associations::JoinDependency)
|
|
33
|
-
stashed_eager_load = joins.pop if joins.last.base_klass ==
|
|
35
|
+
stashed_eager_load = joins.pop if joins.last.base_klass == model
|
|
34
36
|
end
|
|
35
37
|
|
|
36
38
|
joins.each_with_index do |join, i|
|
|
@@ -49,7 +51,7 @@ private
|
|
|
49
51
|
buckets[:named_join] = select_named_joins(joins, buckets[:stashed_join]) do |join|
|
|
50
52
|
if join.is_a?(Arel::Nodes::Join)
|
|
51
53
|
buckets[:join_node] << join
|
|
52
|
-
elsif join.is_a?(CTEJoin)
|
|
54
|
+
elsif join.is_a?(ActiveRecord::QueryMethods::CTEJoin)
|
|
53
55
|
buckets[:join_node] << build_with_join_node(join.name)
|
|
54
56
|
else
|
|
55
57
|
raise "unknown class: %s" % join.class.name
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
1
3
|
module ActiveRecord::Filter::RelationExtension
|
|
2
4
|
|
|
3
|
-
def initialize(
|
|
5
|
+
def initialize(*, **)
|
|
4
6
|
@filters = []
|
|
5
7
|
super
|
|
6
8
|
end
|
|
@@ -49,13 +51,29 @@ module ActiveRecord::Filter::RelationExtension
|
|
|
49
51
|
@filter_clause_factory ||= ActiveRecord::Filter::FilterClauseFactory.new(klass, predicate_builder)
|
|
50
52
|
end
|
|
51
53
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
54
|
+
if ActiveRecord.version >= "8.1"
|
|
55
|
+
def build_arel(aliases = nil)
|
|
56
|
+
arel = super
|
|
57
|
+
my_alias_tracker = ActiveRecord::Associations::AliasTracker.create(model.connection_pool, table.name, [])
|
|
58
|
+
build_filters(arel, my_alias_tracker)
|
|
59
|
+
arel
|
|
60
|
+
end
|
|
61
|
+
elsif ActiveRecord.version >= "7.2"
|
|
62
|
+
def build_arel(connection, aliases = nil)
|
|
63
|
+
arel = super
|
|
64
|
+
my_alias_tracker = ActiveRecord::Associations::AliasTracker.create(model.connection_pool, table.name, [])
|
|
65
|
+
build_filters(arel, my_alias_tracker)
|
|
66
|
+
arel
|
|
67
|
+
end
|
|
68
|
+
else
|
|
69
|
+
def build_arel(aliases = nil)
|
|
70
|
+
arel = super
|
|
71
|
+
my_alias_tracker = ActiveRecord::Associations::AliasTracker.create(connection, table.name, [])
|
|
72
|
+
build_filters(arel, my_alias_tracker)
|
|
73
|
+
arel
|
|
74
|
+
end
|
|
57
75
|
end
|
|
58
|
-
|
|
76
|
+
|
|
59
77
|
def build_filters(manager, alias_tracker)
|
|
60
78
|
@filters.each do |filters|
|
|
61
79
|
manager.where(filter_clause_factory.build(filters, alias_tracker).ast)
|
data/lib/active_record/filter.rb
CHANGED
metadata
CHANGED
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: activerecord-filter
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version:
|
|
4
|
+
version: 8.1.0
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Jon Bracy
|
|
8
|
-
autorequire:
|
|
9
8
|
bindir: bin
|
|
10
9
|
cert_chain: []
|
|
11
|
-
date:
|
|
10
|
+
date: 1980-01-02 00:00:00.000000000 Z
|
|
12
11
|
dependencies:
|
|
13
12
|
- !ruby/object:Gem::Dependency
|
|
14
13
|
name: activerecord
|
|
@@ -16,28 +15,28 @@ dependencies:
|
|
|
16
15
|
requirements:
|
|
17
16
|
- - ">="
|
|
18
17
|
- !ruby/object:Gem::Version
|
|
19
|
-
version: 7.
|
|
18
|
+
version: 7.2.0
|
|
20
19
|
type: :runtime
|
|
21
20
|
prerelease: false
|
|
22
21
|
version_requirements: !ruby/object:Gem::Requirement
|
|
23
22
|
requirements:
|
|
24
23
|
- - ">="
|
|
25
24
|
- !ruby/object:Gem::Version
|
|
26
|
-
version: 7.
|
|
25
|
+
version: 7.2.0
|
|
27
26
|
- !ruby/object:Gem::Dependency
|
|
28
27
|
name: arel-extensions
|
|
29
28
|
requirement: !ruby/object:Gem::Requirement
|
|
30
29
|
requirements:
|
|
31
30
|
- - ">="
|
|
32
31
|
- !ruby/object:Gem::Version
|
|
33
|
-
version: 7.0
|
|
32
|
+
version: 7.2.0
|
|
34
33
|
type: :runtime
|
|
35
34
|
prerelease: false
|
|
36
35
|
version_requirements: !ruby/object:Gem::Requirement
|
|
37
36
|
requirements:
|
|
38
37
|
- - ">="
|
|
39
38
|
- !ruby/object:Gem::Version
|
|
40
|
-
version: 7.0
|
|
39
|
+
version: 7.2.0
|
|
41
40
|
- !ruby/object:Gem::Dependency
|
|
42
41
|
name: pg
|
|
43
42
|
requirement: !ruby/object:Gem::Requirement
|
|
@@ -58,14 +57,14 @@ dependencies:
|
|
|
58
57
|
requirements:
|
|
59
58
|
- - ">="
|
|
60
59
|
- !ruby/object:Gem::Version
|
|
61
|
-
version:
|
|
60
|
+
version: 7.2.0
|
|
62
61
|
type: :development
|
|
63
62
|
prerelease: false
|
|
64
63
|
version_requirements: !ruby/object:Gem::Requirement
|
|
65
64
|
requirements:
|
|
66
65
|
- - ">="
|
|
67
66
|
- !ruby/object:Gem::Version
|
|
68
|
-
version:
|
|
67
|
+
version: 7.2.0
|
|
69
68
|
- !ruby/object:Gem::Dependency
|
|
70
69
|
name: bundler
|
|
71
70
|
requirement: !ruby/object:Gem::Requirement
|
|
@@ -122,6 +121,20 @@ dependencies:
|
|
|
122
121
|
- - ">="
|
|
123
122
|
- !ruby/object:Gem::Version
|
|
124
123
|
version: '0'
|
|
124
|
+
- !ruby/object:Gem::Dependency
|
|
125
|
+
name: benchmark
|
|
126
|
+
requirement: !ruby/object:Gem::Requirement
|
|
127
|
+
requirements:
|
|
128
|
+
- - ">="
|
|
129
|
+
- !ruby/object:Gem::Version
|
|
130
|
+
version: '0'
|
|
131
|
+
type: :development
|
|
132
|
+
prerelease: false
|
|
133
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
134
|
+
requirements:
|
|
135
|
+
- - ">="
|
|
136
|
+
- !ruby/object:Gem::Version
|
|
137
|
+
version: '0'
|
|
125
138
|
- !ruby/object:Gem::Dependency
|
|
126
139
|
name: simplecov
|
|
127
140
|
requirement: !ruby/object:Gem::Requirement
|
|
@@ -142,14 +155,14 @@ dependencies:
|
|
|
142
155
|
requirements:
|
|
143
156
|
- - ">="
|
|
144
157
|
- !ruby/object:Gem::Version
|
|
145
|
-
version:
|
|
158
|
+
version: 7.2.0
|
|
146
159
|
type: :development
|
|
147
160
|
prerelease: false
|
|
148
161
|
version_requirements: !ruby/object:Gem::Requirement
|
|
149
162
|
requirements:
|
|
150
163
|
- - ">="
|
|
151
164
|
- !ruby/object:Gem::Version
|
|
152
|
-
version:
|
|
165
|
+
version: 7.2.0
|
|
153
166
|
- !ruby/object:Gem::Dependency
|
|
154
167
|
name: faker
|
|
155
168
|
requirement: !ruby/object:Gem::Requirement
|
|
@@ -215,7 +228,6 @@ homepage: https://github.com/malomalo/activerecord-filter
|
|
|
215
228
|
licenses:
|
|
216
229
|
- MIT
|
|
217
230
|
metadata: {}
|
|
218
|
-
post_install_message:
|
|
219
231
|
rdoc_options:
|
|
220
232
|
- "--main"
|
|
221
233
|
- README.md
|
|
@@ -232,8 +244,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
|
232
244
|
- !ruby/object:Gem::Version
|
|
233
245
|
version: '0'
|
|
234
246
|
requirements: []
|
|
235
|
-
rubygems_version:
|
|
236
|
-
signing_key:
|
|
247
|
+
rubygems_version: 4.0.2
|
|
237
248
|
specification_version: 4
|
|
238
249
|
summary: A safe way to accept user parameters and query against your ActiveRecord
|
|
239
250
|
Models
|