denormalize_fields 1.1.2 → 1.2.0
Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: f75e3e551412d74ece84cd1369cf35350d9bf089fe1fecb2a635983dae2c8aaf
|
4
|
+
data.tar.gz: 4bb30e1378174f374fddbd41e48857236a1991ee828f7c440b518f910273f870
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d4987aec2cf44f282450b8a6a6aaf2bc80af4ca362c31fcf05320328a9b4cda4db0f3ffda7e2744ce0352bb08b533285d705a2c29a327ac6a499580c58b9d034
|
7
|
+
data.tar.gz: e5460b437851d87fd9be891f10c921e1160e93184a186a97435bc059d32b5a07ce0fe8d9ee50e1724282fe6c0a2e66764bcb250cb79df5f900fb1a11c6516775
|
@@ -12,10 +12,9 @@ module DenormalizeFields
|
|
12
12
|
return unless options = association.options[OPTION]
|
13
13
|
|
14
14
|
DenormalizeFields.denormalize(
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
prefix: options[:prefix],
|
15
|
+
from: association.active_record,
|
16
|
+
onto: association.name,
|
17
|
+
**options,
|
19
18
|
)
|
20
19
|
end
|
21
20
|
end
|
data/lib/denormalize_fields.rb
CHANGED
@@ -4,14 +4,36 @@ require 'denormalize_fields/version'
|
|
4
4
|
module DenormalizeFields
|
5
5
|
module_function
|
6
6
|
|
7
|
-
def denormalize(fields:, from:, onto:, prefix: nil)
|
7
|
+
def denormalize(fields:, from:, onto:, prefix: nil, **options)
|
8
8
|
mapping = cast_to_mapping(fields, prefix: prefix)
|
9
|
+
validate_options(**options)
|
9
10
|
|
10
11
|
from.after_save do
|
11
|
-
DenormalizeFields.call(
|
12
|
+
DenormalizeFields.call(
|
13
|
+
record: self,
|
14
|
+
relation_name: onto,
|
15
|
+
mapping: mapping,
|
16
|
+
**options,
|
17
|
+
)
|
12
18
|
end
|
13
19
|
end
|
14
20
|
|
21
|
+
def validate_options(**options)
|
22
|
+
validate_conditional(options[:if])
|
23
|
+
validate_conditional(options[:unless])
|
24
|
+
unsupported = (options.keys - %i[if unless]).empty? ||
|
25
|
+
raise(ArgumentError, "unsupported denormalize options: #{unsupported}")
|
26
|
+
end
|
27
|
+
|
28
|
+
CONDITIONAL_CLASSES = [NilClass, TrueClass, FalseClass, Symbol, Proc]
|
29
|
+
|
30
|
+
def validate_conditional(arg)
|
31
|
+
CONDITIONAL_CLASSES.include?(arg.class) || raise(
|
32
|
+
ArgumentError,
|
33
|
+
"`if:` option must be a #{CONDITIONAL_CLASSES.join('/')}, got: #{arg.class}"
|
34
|
+
)
|
35
|
+
end
|
36
|
+
|
15
37
|
def cast_to_mapping(fields, prefix: nil)
|
16
38
|
if fields.is_a?(Hash)
|
17
39
|
prefix && raise(ArgumentError, 'pass EITHER a fields Hash OR a prefix')
|
@@ -21,7 +43,10 @@ module DenormalizeFields
|
|
21
43
|
end
|
22
44
|
end
|
23
45
|
|
24
|
-
def call(record:, relation_name:, mapping
|
46
|
+
def call(record:, relation_name:, mapping:, **options)
|
47
|
+
return unless conditional_passes?(options[:if], record, false)
|
48
|
+
return unless conditional_passes?(options[:unless], record, true)
|
49
|
+
|
25
50
|
changeset = DenormalizeFields.changeset(record: record, mapping: mapping)
|
26
51
|
return if changeset.empty?
|
27
52
|
|
@@ -32,6 +57,21 @@ module DenormalizeFields
|
|
32
57
|
end
|
33
58
|
end
|
34
59
|
|
60
|
+
def conditional_passes?(conditional, record, inverted)
|
61
|
+
return true if conditional.nil?
|
62
|
+
|
63
|
+
result =
|
64
|
+
if conditional.respond_to?(:call)
|
65
|
+
record.instance_exec(&conditional)
|
66
|
+
elsif conditional.class == Symbol
|
67
|
+
record.send(conditional)
|
68
|
+
else # true, false
|
69
|
+
conditional
|
70
|
+
end
|
71
|
+
|
72
|
+
inverted ? !result : !!result
|
73
|
+
end
|
74
|
+
|
35
75
|
def changeset(record:, mapping:)
|
36
76
|
mapping.each.with_object({}) do |(source, dest), hash|
|
37
77
|
if source.is_a?(Array)
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: denormalize_fields
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Janosch Müller
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-11-28 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -136,7 +136,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
136
136
|
- !ruby/object:Gem::Version
|
137
137
|
version: '0'
|
138
138
|
requirements: []
|
139
|
-
rubygems_version: 3.2.
|
139
|
+
rubygems_version: 3.2.3
|
140
140
|
signing_key:
|
141
141
|
specification_version: 4
|
142
142
|
summary: Simplify denormalizing fields from one record to another.
|