key-vortex 0.1.3 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.reek.yml +5 -0
- data/.rubocop.yml +4 -0
- data/Gemfile.lock +1 -1
- data/Guardfile +1 -1
- data/lib/key_vortex/adapter/memory.rb +1 -1
- data/lib/key_vortex/constraint/base.rb +2 -2
- data/lib/key_vortex/constraint/length.rb +9 -5
- data/lib/key_vortex/constraint/maximum.rb +9 -5
- data/lib/key_vortex/constraint/minimum.rb +9 -5
- data/lib/key_vortex/field.rb +6 -2
- data/lib/key_vortex/limitation.rb +24 -6
- data/lib/key_vortex/record.rb +23 -14
- data/lib/key_vortex/version.rb +1 -1
- data/lib/key_vortex.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a34f3ac120e1d77828821334095974c96448d82df26ab5464370e46bc610adb2
|
4
|
+
data.tar.gz: dd955d832e5a15a37362cd8fe536e0851377e7e2fd0812aebd47b64944fc8039
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: e2ffcd6c05e930f8faba12aacf5ccfc2a004b5e27d8ec0785f0b9c939e61347bec7ff4e339fab98f31b948d966a4722bfd1831bbbc4da53a23d9c0a2ab115c31
|
7
|
+
data.tar.gz: 3bc5641c8b9bc9c5e55dc5dbf299e968e9793a53aba261410885d4fda9689829aaa3c052169c7b79367d414a389fc5dd33a36a87e47545869ba3fa10d5023bd6
|
data/.reek.yml
CHANGED
data/.rubocop.yml
CHANGED
data/Gemfile.lock
CHANGED
data/Guardfile
CHANGED
@@ -27,7 +27,7 @@
|
|
27
27
|
# * 'just' rspec: 'rspec'
|
28
28
|
|
29
29
|
group :red_green_refactor, halt_on_fail: true do
|
30
|
-
guard :rspec, cmd: "bundle exec rspec", all_on_pass: true do
|
30
|
+
guard :rspec, cmd: "bundle exec rspec", failed_mode: :focus, all_on_pass: true do
|
31
31
|
require "guard/rspec/dsl"
|
32
32
|
dsl = Guard::RSpec::Dsl.new(self)
|
33
33
|
|
@@ -8,11 +8,11 @@ class KeyVortex
|
|
8
8
|
end
|
9
9
|
|
10
10
|
def within?(constraint)
|
11
|
-
|
11
|
+
constraint.instance_of?(self.class)
|
12
12
|
end
|
13
13
|
|
14
14
|
def to_s
|
15
|
-
"#{attribute}: #{
|
15
|
+
"#{attribute}: #{limit}"
|
16
16
|
end
|
17
17
|
end
|
18
18
|
end
|
@@ -5,19 +5,23 @@ require "key_vortex/constraint/base"
|
|
5
5
|
class KeyVortex
|
6
6
|
class Constraint
|
7
7
|
class Length < KeyVortex::Constraint::Base
|
8
|
-
attr_reader :
|
8
|
+
attr_reader :limit
|
9
9
|
|
10
|
-
def initialize(
|
10
|
+
def initialize(limit)
|
11
11
|
super()
|
12
|
-
@
|
12
|
+
@limit = limit
|
13
13
|
end
|
14
14
|
|
15
15
|
def attribute
|
16
16
|
:length
|
17
17
|
end
|
18
18
|
|
19
|
-
def
|
20
|
-
|
19
|
+
def within?(constraint)
|
20
|
+
super && limit <= constraint.limit
|
21
|
+
end
|
22
|
+
|
23
|
+
def accepts?(value)
|
24
|
+
value.length <= limit
|
21
25
|
end
|
22
26
|
end
|
23
27
|
end
|
@@ -5,19 +5,23 @@ require "key_vortex/constraint/base"
|
|
5
5
|
class KeyVortex
|
6
6
|
class Constraint
|
7
7
|
class Maximum < KeyVortex::Constraint::Base
|
8
|
-
attr_reader :
|
8
|
+
attr_reader :limit
|
9
9
|
|
10
|
-
def initialize(
|
10
|
+
def initialize(limit)
|
11
11
|
super()
|
12
|
-
@
|
12
|
+
@limit = limit
|
13
13
|
end
|
14
14
|
|
15
15
|
def attribute
|
16
16
|
:maximum
|
17
17
|
end
|
18
18
|
|
19
|
-
def
|
20
|
-
|
19
|
+
def within?(constraint)
|
20
|
+
super && limit <= constraint.limit
|
21
|
+
end
|
22
|
+
|
23
|
+
def accepts?(value)
|
24
|
+
value <= limit
|
21
25
|
end
|
22
26
|
end
|
23
27
|
end
|
@@ -5,19 +5,23 @@ require "key_vortex/constraint/base"
|
|
5
5
|
class KeyVortex
|
6
6
|
class Constraint
|
7
7
|
class Minimum < KeyVortex::Constraint::Base
|
8
|
-
attr_reader :
|
8
|
+
attr_reader :limit
|
9
9
|
|
10
|
-
def initialize(
|
10
|
+
def initialize(limit)
|
11
11
|
super()
|
12
|
-
@
|
12
|
+
@limit = limit
|
13
13
|
end
|
14
14
|
|
15
15
|
def attribute
|
16
16
|
:maximum
|
17
17
|
end
|
18
18
|
|
19
|
-
def
|
20
|
-
|
19
|
+
def within?(constraint)
|
20
|
+
super && limit >= constraint.limit
|
21
|
+
end
|
22
|
+
|
23
|
+
def accepts?(value)
|
24
|
+
value >= limit
|
21
25
|
end
|
22
26
|
end
|
23
27
|
end
|
data/lib/key_vortex/field.rb
CHANGED
@@ -17,9 +17,13 @@ class KeyVortex
|
|
17
17
|
end)
|
18
18
|
end
|
19
19
|
|
20
|
-
def
|
20
|
+
def within?(adapter)
|
21
21
|
limitation = adapter.limitation_for(self)
|
22
|
-
limitation
|
22
|
+
!limitation || self.limitation.within?(limitation)
|
23
|
+
end
|
24
|
+
|
25
|
+
def accepts?(value)
|
26
|
+
limitation.accepts?(value)
|
23
27
|
end
|
24
28
|
end
|
25
29
|
end
|
@@ -20,22 +20,40 @@ class KeyVortex
|
|
20
20
|
@constraints += constraints
|
21
21
|
end
|
22
22
|
|
23
|
-
def
|
23
|
+
def encompasses?(limitation)
|
24
24
|
@constraints.all? do |constraint|
|
25
|
-
limitation.
|
25
|
+
limitation.encompasses_constraint?(constraint)
|
26
26
|
end
|
27
27
|
end
|
28
28
|
|
29
|
-
def
|
30
|
-
!
|
29
|
+
def encompasses_constraint?(constraint)
|
30
|
+
!applicable_constraints(constraint).select do |con|
|
31
|
+
con.within?(constraint)
|
32
|
+
end.empty?
|
33
|
+
end
|
34
|
+
|
35
|
+
def within?(limitation)
|
36
|
+
limitation.constraints.all? do |constraint|
|
37
|
+
within_constraint?(constraint)
|
38
|
+
end
|
31
39
|
end
|
32
40
|
|
33
|
-
def
|
34
|
-
|
41
|
+
def within_constraint?(constraint)
|
42
|
+
!applicable_constraints(constraint).select do |con|
|
35
43
|
con.within?(constraint)
|
44
|
+
end.empty?
|
45
|
+
end
|
46
|
+
|
47
|
+
def applicable_constraints(constraint)
|
48
|
+
@constraints.select do |con|
|
49
|
+
con.applies_to?(constraint)
|
36
50
|
end
|
37
51
|
end
|
38
52
|
|
53
|
+
def accepts?(value)
|
54
|
+
value.is_a?(type) && @constraints.all? { |constraint| constraint.accepts?(value) }
|
55
|
+
end
|
56
|
+
|
39
57
|
def to_s
|
40
58
|
"Limitation: #{@type}\n\t#{@constraints.join('\n\t')}"
|
41
59
|
end
|
data/lib/key_vortex/record.rb
CHANGED
@@ -19,8 +19,26 @@ class KeyVortex
|
|
19
19
|
register_field(KeyVortex::Field.new(name, type, **constraints_hash))
|
20
20
|
end
|
21
21
|
|
22
|
+
def self.field_constraints(field)
|
23
|
+
@field_hash[field]
|
24
|
+
end
|
25
|
+
|
22
26
|
def self.register_field(field)
|
23
27
|
field_hash[field.name] = field
|
28
|
+
define_getter(field)
|
29
|
+
define_setter(field)
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.define_getter(field)
|
33
|
+
define_method(field.name) { @values[field.name] }
|
34
|
+
end
|
35
|
+
|
36
|
+
def self.define_setter(field)
|
37
|
+
define_method("#{field.name}=") do |val|
|
38
|
+
raise KeyVortex::Error, "Invalid value #{val} for #{field.name}" unless field.accepts?(val)
|
39
|
+
|
40
|
+
@values[field.name] = val
|
41
|
+
end
|
24
42
|
end
|
25
43
|
|
26
44
|
def self.inherited(subclass)
|
@@ -33,20 +51,11 @@ class KeyVortex
|
|
33
51
|
# Long enough to accomodate a GUID
|
34
52
|
field :key, String, length: 36
|
35
53
|
|
36
|
-
def initialize(
|
37
|
-
@
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
args.empty? && self.class.field_constraints(method)
|
42
|
-
end
|
43
|
-
|
44
|
-
def method_missing(method, *_args)
|
45
|
-
@field_hash[method]
|
46
|
-
end
|
47
|
-
|
48
|
-
def self.field_constraints(field)
|
49
|
-
@field_hash[field]
|
54
|
+
def initialize(values = {})
|
55
|
+
@values = {}
|
56
|
+
values.each do |name, value|
|
57
|
+
send("#{name}=", value)
|
58
|
+
end
|
50
59
|
end
|
51
60
|
end
|
52
61
|
end
|
data/lib/key_vortex/version.rb
CHANGED
data/lib/key_vortex.rb
CHANGED
@@ -10,7 +10,7 @@ class KeyVortex
|
|
10
10
|
@record_class = record_class
|
11
11
|
|
12
12
|
record_class.fields.each do |field|
|
13
|
-
next
|
13
|
+
next if field.within?(adapter)
|
14
14
|
|
15
15
|
raise KeyVortex::Error,
|
16
16
|
"#{adapter.class} can only handle field #{field.name} with these limitations:\n" +
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: key-vortex
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Lambda Null
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-07-
|
11
|
+
date: 2023-07-10 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: Defines abstractions that can be built on top of for key/value storage
|
14
14
|
on different technologies (file, s3, sql, redis, etc.)
|