tram-policy 1.0.0 → 2.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.gitignore +1 -0
- data/.travis.yml +4 -7
- data/CHANGELOG.md +34 -0
- data/README.md +1 -4
- data/lib/tram/policy/dsl.rb +2 -2
- data/lib/tram/policy/error.rb +12 -8
- data/lib/tram/policy/errors.rb +13 -11
- data/lib/tram/policy/rspec.rb +7 -2
- data/lib/tram/policy.rb +2 -2
- data/spec/tram/policy/error_spec.rb +3 -2
- data/spec/tram/policy/errors_spec.rb +17 -17
- data/spec/tram/policy/rspec_spec.rb +15 -0
- data/spec/tram/policy_spec.rb +2 -2
- data/tram-policy.gemspec +3 -3
- metadata +14 -9
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
|
-
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
2
|
+
SHA256:
|
3
|
+
metadata.gz: 3bf029c2eff265f0a29f13d7f1c44b8f8a1a9d5a336a61a9804c9740142eba17
|
4
|
+
data.tar.gz: ccee1509e523eeb4e55208b357e561f03100844d32ec3a14d879ad6991b8f538
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d193c0d20344f0ab8c2b015e7a5eee330ef4fec64182c298ad750b06081894d6d8f51d89c064bc8aa7561e7f8d68ccd3f03f55a4378677781ba0bdf4e8376cd0
|
7
|
+
data.tar.gz: 0b0214db5420f51dadb31028d1a75b2cb54b762ccf013d6948a6eb47fb2b6ca4825dfe747921b80aa732de0b27e89faf74a353a005a5c0237c0267df8681a421
|
data/.gitignore
CHANGED
data/.travis.yml
CHANGED
@@ -8,18 +8,15 @@ script:
|
|
8
8
|
- bundle exec rubocop
|
9
9
|
rvm:
|
10
10
|
- 2.3.0
|
11
|
-
- 2.
|
11
|
+
- 2.6.2
|
12
12
|
- ruby-head
|
13
|
-
- jruby-9.
|
14
|
-
-
|
13
|
+
- jruby-9.2.7.0
|
14
|
+
- truffleruby
|
15
15
|
env:
|
16
16
|
global:
|
17
17
|
- JRUBY_OPTS='--dev -J-Xmx1024M'
|
18
18
|
matrix:
|
19
19
|
allow_failures:
|
20
|
-
- rvm: rbx-3
|
21
20
|
- rvm: ruby-head
|
22
21
|
- rvm: jruby-head
|
23
|
-
|
24
|
-
- rvm: jruby-head
|
25
|
-
before_install: gem install bundler --no-ri --no-rdoc
|
22
|
+
- rvm: truffleruby
|
data/CHANGELOG.md
CHANGED
@@ -4,6 +4,35 @@ All notable changes to this project will be documented in this file.
|
|
4
4
|
The format is based on [Keep a Changelog](http://keepachangelog.com/)
|
5
5
|
and this project adheres to [Semantic Versioning](http://semver.org/).
|
6
6
|
|
7
|
+
## [2.1.0] - [2021-11-30]
|
8
|
+
|
9
|
+
### Fixed
|
10
|
+
- Difference between last positional and keyword arguments in Ruby 3.0+ (mrexox)
|
11
|
+
|
12
|
+
## [2.0.1] - [2019-11-14]
|
13
|
+
|
14
|
+
### Fixed
|
15
|
+
- Allow translation :scope to be customized in the #merge operation (sclinede)
|
16
|
+
Before the fix, the customized value was always replaced by the default value.
|
17
|
+
|
18
|
+
## [2.0.0] - [2019-07-04]
|
19
|
+
|
20
|
+
### Changed
|
21
|
+
|
22
|
+
- [BREAKING] separate `Tram::Policy::Errors` from a policy (nepalez, sclinede)
|
23
|
+
|
24
|
+
Instead of the policy, the collection refers to the explicit scope used for error messages' translation.
|
25
|
+
This change breaks the signature of `Tram::Policy::Error` and `Tram::Policy::Errors`.
|
26
|
+
|
27
|
+
## [1.0.1] - [2019-05-06]
|
28
|
+
|
29
|
+
### Added
|
30
|
+
- Support of `dry-initializer` v3.0+ (nepalez)
|
31
|
+
|
32
|
+
### Fixed
|
33
|
+
- Fix be_invalid RSpec matcher if non-policy model is passed (Envek)
|
34
|
+
- Disable translation check for non-strings in rspec matcher (Envek)
|
35
|
+
|
7
36
|
## [1.0.0] - [2018-02-17]
|
8
37
|
|
9
38
|
### Changed
|
@@ -191,3 +220,8 @@ This is a first public release (@nepalez, @charlie-wasp, @JewelSam, @sergey-chec
|
|
191
220
|
[0.3.0]: https://github.com/tram-rb/tram-policy/compare/v0.2.5...v0.3.0
|
192
221
|
[0.3.1]: https://github.com/tram-rb/tram-policy/compare/v0.3.0...v0.3.1
|
193
222
|
[0.4.0]: https://github.com/tram-rb/tram-policy/compare/v0.3.1...v0.4.0
|
223
|
+
[1.0.0]: https://github.com/tram-rb/tram-policy/compare/v0.4.0...v1.0.0
|
224
|
+
[1.0.1]: https://github.com/tram-rb/tram-policy/compare/v1.0.0...v1.0.1
|
225
|
+
[2.0.0]: https://github.com/tram-rb/tram-policy/compare/v1.0.1...v2.0.0
|
226
|
+
[2.0.1]: https://github.com/tram-rb/tram-policy/compare/v2.0.0...v2.0.1
|
227
|
+
[2.1.0]: https://github.com/tram-rb/tram-policy/compare/v2.0.1...v2.1.0
|
data/README.md
CHANGED
@@ -7,7 +7,6 @@ Policy Object Pattern
|
|
7
7
|
|
8
8
|
[![Gem Version][gem-badger]][gem]
|
9
9
|
[![Build Status][travis-badger]][travis]
|
10
|
-
[![Dependency Status][gemnasium-badger]][gemnasium]
|
11
10
|
[![Inline docs][inch-badger]][inch]
|
12
11
|
|
13
12
|
## Intro
|
@@ -128,7 +127,7 @@ You can change the root scope if you will (this could be useful in libraries):
|
|
128
127
|
|
129
128
|
```ruby
|
130
129
|
class MyGemPolicy < Tram::Policy
|
131
|
-
|
130
|
+
root_scope "mygem", "policies" # inherited by subclasses
|
132
131
|
end
|
133
132
|
|
134
133
|
class Article::ReadinessPolicy < MyGemPolicy
|
@@ -338,8 +337,6 @@ The gem is available as open source under the terms of the [MIT License](http://
|
|
338
337
|
[codeclimate]: https://codeclimate.com/github/tram-rb/tram-policy
|
339
338
|
[gem-badger]: https://img.shields.io/gem/v/tram-policy.svg?style=flat
|
340
339
|
[gem]: https://rubygems.org/gems/tram-policy
|
341
|
-
[gemnasium-badger]: https://img.shields.io/gemnasium/tram-rb/tram-policy.svg?style=flat
|
342
|
-
[gemnasium]: https://gemnasium.com/tram-rb/tram-policy
|
343
340
|
[inch-badger]: http://inch-ci.org/github/tram-rb/tram-policy.svg
|
344
341
|
[inch]: https://inch-ci.org/github/tram-rb/tram-policy
|
345
342
|
[travis-badger]: https://img.shields.io/travis/tram-rb/tram-policy/master.svg?style=flat
|
data/lib/tram/policy/dsl.rb
CHANGED
data/lib/tram/policy/error.rb
CHANGED
@@ -12,10 +12,10 @@ class Tram::Policy
|
|
12
12
|
# If another error is send to the constructor, the error returned unchanged
|
13
13
|
#
|
14
14
|
# @param [Tram::Policy::Error, #to_s] value
|
15
|
-
# @param [Hash<Symbol, Object>]
|
15
|
+
# @param [Hash<Symbol, Object>] tags
|
16
16
|
# @return [Tram::Policy::Error]
|
17
17
|
#
|
18
|
-
def self.new(value, **
|
18
|
+
def self.new(value, **tags)
|
19
19
|
value.instance_of?(self) ? value : super
|
20
20
|
end
|
21
21
|
|
@@ -27,7 +27,7 @@ class Tram::Policy
|
|
27
27
|
# @return [Hash<Symbol, Object>] error tags
|
28
28
|
attr_reader :tags
|
29
29
|
|
30
|
-
#
|
30
|
+
# List of arguments for [I18n.t]
|
31
31
|
#
|
32
32
|
# @return [Array]
|
33
33
|
#
|
@@ -36,7 +36,7 @@ class Tram::Policy
|
|
36
36
|
end
|
37
37
|
alias to_a item
|
38
38
|
|
39
|
-
#
|
39
|
+
# Text of error message translated to the current locale
|
40
40
|
#
|
41
41
|
# @return [String]
|
42
42
|
#
|
@@ -60,8 +60,8 @@ class Tram::Policy
|
|
60
60
|
# @param [Proc] block
|
61
61
|
# @return [Object]
|
62
62
|
#
|
63
|
-
def fetch(tag, default =
|
64
|
-
if default ==
|
63
|
+
def fetch(tag, default = UNDEFINED, &block)
|
64
|
+
if default == UNDEFINED
|
65
65
|
tags.fetch(tag.to_sym, &block)
|
66
66
|
else
|
67
67
|
tags.fetch(tag.to_sym, default, &block)
|
@@ -92,17 +92,21 @@ class Tram::Policy
|
|
92
92
|
|
93
93
|
private
|
94
94
|
|
95
|
+
UNDEFINED = Dry::Initializer::UNDEFINED
|
96
|
+
DEFAULT_SCOPE = %w[tram-policy errors].freeze
|
97
|
+
|
95
98
|
def initialize(key, **tags)
|
96
99
|
@key = key
|
97
100
|
@tags = tags
|
101
|
+
@tags[:scope] = @tags.fetch(:scope) { DEFAULT_SCOPE } if key.is_a?(Symbol)
|
98
102
|
end
|
99
103
|
|
100
104
|
def respond_to_missing?(*)
|
101
105
|
true
|
102
106
|
end
|
103
107
|
|
104
|
-
def method_missing(name, *args, &block)
|
105
|
-
args.any? || block ? super : tags[name]
|
108
|
+
def method_missing(name, *args, **kwargs, &block)
|
109
|
+
args.any? || kwargs.any? || block ? super : tags[name]
|
106
110
|
end
|
107
111
|
end
|
108
112
|
end
|
data/lib/tram/policy/errors.rb
CHANGED
@@ -1,4 +1,5 @@
|
|
1
1
|
class Tram::Policy
|
2
|
+
#
|
2
3
|
# Enumerable collection of unique unordered validation errors
|
3
4
|
#
|
4
5
|
# Notice: A collection is context-dependent;
|
@@ -8,11 +9,9 @@ class Tram::Policy
|
|
8
9
|
class Errors
|
9
10
|
include Enumerable
|
10
11
|
|
11
|
-
# @!attribute [r]
|
12
|
-
#
|
13
|
-
|
14
|
-
#
|
15
|
-
attr_reader :policy
|
12
|
+
# @!attribute [r] scope
|
13
|
+
# @return [Array<String>] the scope for error messages' translation
|
14
|
+
attr_reader :scope
|
16
15
|
|
17
16
|
# @!method add(message, tags)
|
18
17
|
# Adds error message to the collection
|
@@ -22,9 +21,12 @@ class Tram::Policy
|
|
22
21
|
# @return [self] the collection
|
23
22
|
#
|
24
23
|
def add(message, **tags)
|
25
|
-
tags = tags.merge(scope: policy.scope) unless tags.key?(:scope)
|
26
24
|
raise ArgumentError.new("Error message should be defined") unless message
|
27
|
-
|
25
|
+
|
26
|
+
tap do
|
27
|
+
tags = { scope: scope }.merge(tags) if message.is_a?(Symbol)
|
28
|
+
@set << Tram::Policy::Error.new(message, **tags)
|
29
|
+
end
|
28
30
|
end
|
29
31
|
|
30
32
|
# Iterates by collected errors
|
@@ -47,7 +49,7 @@ class Tram::Policy
|
|
47
49
|
list = each_with_object(Set.new) do |error, obj|
|
48
50
|
obj << error if error.contain?(key, tags)
|
49
51
|
end
|
50
|
-
self.class.new(
|
52
|
+
self.class.new(scope: scope, errors: list)
|
51
53
|
end
|
52
54
|
|
53
55
|
# @!method empty?
|
@@ -101,9 +103,9 @@ class Tram::Policy
|
|
101
103
|
|
102
104
|
private
|
103
105
|
|
104
|
-
def initialize(
|
105
|
-
@
|
106
|
-
@set
|
106
|
+
def initialize(**options)
|
107
|
+
@scope = options[:scope] || Error::DEFAULT_SCOPE
|
108
|
+
@set = Set.new options[:errors].to_a
|
107
109
|
end
|
108
110
|
end
|
109
111
|
end
|
data/lib/tram/policy/rspec.rb
CHANGED
@@ -17,8 +17,11 @@ RSpec::Matchers.define :be_invalid_at do |**tags|
|
|
17
17
|
|
18
18
|
def missed_translations
|
19
19
|
@missed_translations ||= \
|
20
|
-
errors
|
21
|
-
|
20
|
+
errors
|
21
|
+
.flat_map { |rec| rec.values_at(*locales) }
|
22
|
+
.select do |message|
|
23
|
+
message.is_a?(String) && message.start_with?("translation missing")
|
24
|
+
end
|
22
25
|
end
|
23
26
|
|
24
27
|
def report_errors
|
@@ -57,10 +60,12 @@ end
|
|
57
60
|
|
58
61
|
RSpec::Matchers.define :be_invalid do
|
59
62
|
match do |policy|
|
63
|
+
return expect(policy.valid?).to(be_falsey) unless policy.is_a?(Tram::Policy)
|
60
64
|
expect(policy).to be_invalid_at
|
61
65
|
end
|
62
66
|
|
63
67
|
match_when_negated do |policy|
|
68
|
+
return expect(policy.valid?).to(be_truthy) unless policy.is_a?(Tram::Policy)
|
64
69
|
expect(policy).not_to be_invalid_at
|
65
70
|
end
|
66
71
|
end
|
data/lib/tram/policy.rb
CHANGED
@@ -40,7 +40,7 @@ module Tram
|
|
40
40
|
# @return [Tram::Policy::Errors]
|
41
41
|
#
|
42
42
|
def errors
|
43
|
-
@errors ||= Errors.new(
|
43
|
+
@errors ||= Errors.new(scope: scope)
|
44
44
|
end
|
45
45
|
|
46
46
|
# The array of error items for lazy translation
|
@@ -101,7 +101,7 @@ module Tram
|
|
101
101
|
|
102
102
|
private
|
103
103
|
|
104
|
-
def initialize(
|
104
|
+
def initialize(*, **)
|
105
105
|
super
|
106
106
|
|
107
107
|
self.class.validators.each do |validator|
|
@@ -1,11 +1,12 @@
|
|
1
1
|
RSpec.describe Tram::Policy::Error do
|
2
2
|
subject(:error) { described_class.new :bad, options }
|
3
3
|
|
4
|
-
let(:
|
4
|
+
let(:scope) { %w[tram-policy] }
|
5
|
+
let(:options) { { level: "warning", scope: scope } }
|
5
6
|
|
6
7
|
describe "#item" do
|
7
8
|
subject { error.item }
|
8
|
-
it { is_expected.to eq [:bad, level: "warning", scope:
|
9
|
+
it { is_expected.to eq [:bad, level: "warning", scope: scope] }
|
9
10
|
end
|
10
11
|
|
11
12
|
describe "#message" do
|
@@ -1,6 +1,6 @@
|
|
1
1
|
RSpec.describe Tram::Policy::Errors do
|
2
|
-
let(:
|
3
|
-
let(:errors) { described_class.new(
|
2
|
+
let(:scope) { %w[tram-policy] }
|
3
|
+
let(:errors) { described_class.new(scope: scope) }
|
4
4
|
|
5
5
|
describe ".new" do
|
6
6
|
subject { errors }
|
@@ -8,7 +8,7 @@ RSpec.describe Tram::Policy::Errors do
|
|
8
8
|
it { is_expected.to be_kind_of Enumerable }
|
9
9
|
it { is_expected.to respond_to :empty? }
|
10
10
|
it { is_expected.to be_empty }
|
11
|
-
its(:
|
11
|
+
its(:scope) { is_expected.to eql scope }
|
12
12
|
end
|
13
13
|
|
14
14
|
describe "#add" do
|
@@ -21,7 +21,7 @@ RSpec.describe Tram::Policy::Errors do
|
|
21
21
|
|
22
22
|
expect(error).to be_kind_of Tram::Policy::Error
|
23
23
|
expect(error)
|
24
|
-
.to eq [:omg, level: "info", field: "name", scope:
|
24
|
+
.to eq [:omg, level: "info", field: "name", scope: scope]
|
25
25
|
end
|
26
26
|
end
|
27
27
|
|
@@ -45,11 +45,11 @@ RSpec.describe Tram::Policy::Errors do
|
|
45
45
|
end
|
46
46
|
|
47
47
|
describe "#merge" do
|
48
|
-
let(:other) { described_class.new(
|
48
|
+
let(:other) { described_class.new(scope: scope) }
|
49
49
|
|
50
50
|
before do
|
51
|
-
errors.add "D'OH!", level: "disaster"
|
52
|
-
other.add "OUCH!",
|
51
|
+
errors.add :"D'OH!", level: "disaster"
|
52
|
+
other.add "OUCH!", level: "error"
|
53
53
|
end
|
54
54
|
|
55
55
|
context "without a block:" do
|
@@ -58,8 +58,8 @@ RSpec.describe Tram::Policy::Errors do
|
|
58
58
|
it "merges other collection as is" do
|
59
59
|
expect(subject).to be_a Tram::Policy::Errors
|
60
60
|
expect(subject.items).to match_array [
|
61
|
-
["D'OH!", level: "disaster", scope:
|
62
|
-
["OUCH!", level: "error"
|
61
|
+
[:"D'OH!", level: "disaster", scope: scope],
|
62
|
+
["OUCH!", level: "error"]
|
63
63
|
]
|
64
64
|
end
|
65
65
|
end
|
@@ -70,8 +70,8 @@ RSpec.describe Tram::Policy::Errors do
|
|
70
70
|
it "merges filtered collection as is" do
|
71
71
|
expect(subject).to be_a Tram::Policy::Errors
|
72
72
|
expect(subject.items).to match_array [
|
73
|
-
["D'OH!", level: "disaster", scope:
|
74
|
-
["OUCH!", level: "error",
|
73
|
+
[:"D'OH!", level: "disaster", scope: scope],
|
74
|
+
["OUCH!", level: "error", source: "Homer"]
|
75
75
|
]
|
76
76
|
end
|
77
77
|
end
|
@@ -82,8 +82,8 @@ RSpec.describe Tram::Policy::Errors do
|
|
82
82
|
it "merges other collection with given options" do
|
83
83
|
expect(subject).to be_a Tram::Policy::Errors
|
84
84
|
expect(subject.items).to match_array [
|
85
|
-
["D'OH!", level: "disaster", scope:
|
86
|
-
["OUCH!", level: "error",
|
85
|
+
[:"D'OH!", level: "disaster", scope: scope],
|
86
|
+
["OUCH!", level: "error", source: "Homer"]
|
87
87
|
]
|
88
88
|
end
|
89
89
|
end
|
@@ -94,8 +94,8 @@ RSpec.describe Tram::Policy::Errors do
|
|
94
94
|
it "merges filtered collection with given options" do
|
95
95
|
expect(subject).to be_a Tram::Policy::Errors
|
96
96
|
expect(subject.items).to match_array [
|
97
|
-
["D'OH!", level: "disaster", scope:
|
98
|
-
["OUCH!", level: "error",
|
97
|
+
[:"D'OH!", level: "disaster", scope: scope],
|
98
|
+
["OUCH!", level: "error", id: 5, age: 4]
|
99
99
|
]
|
100
100
|
end
|
101
101
|
end
|
@@ -125,8 +125,8 @@ RSpec.describe Tram::Policy::Errors do
|
|
125
125
|
|
126
126
|
it "returns selected errors only" do
|
127
127
|
expect(subject).to match_array [
|
128
|
-
[:foo, field: "name", level: "error", scope:
|
129
|
-
[:foo, field: "email", level: "error", scope:
|
128
|
+
[:foo, field: "name", level: "error", scope: scope],
|
129
|
+
[:foo, field: "email", level: "error", scope: scope]
|
130
130
|
]
|
131
131
|
end
|
132
132
|
end
|
@@ -46,4 +46,19 @@ RSpec.describe "RSpec support:" do
|
|
46
46
|
.to raise_error RSpec::Expectations::ExpectationNotMetError
|
47
47
|
end
|
48
48
|
end
|
49
|
+
|
50
|
+
describe "to be_invalid" do
|
51
|
+
subject { double("model") }
|
52
|
+
|
53
|
+
it "fails with valid non-policy object" do
|
54
|
+
allow(subject).to receive(:valid?).and_return(true)
|
55
|
+
expect { expect(subject).to be_invalid }
|
56
|
+
.to raise_error RSpec::Expectations::ExpectationNotMetError
|
57
|
+
end
|
58
|
+
|
59
|
+
it "passes with invalid non-policy object" do
|
60
|
+
allow(subject).to receive(:valid?).and_return(false)
|
61
|
+
expect { expect(subject).to be_invalid }.not_to raise_error
|
62
|
+
end
|
63
|
+
end
|
49
64
|
end
|
data/spec/tram/policy_spec.rb
CHANGED
@@ -63,8 +63,8 @@ RSpec.describe Tram::Policy do
|
|
63
63
|
describe "#errors" do
|
64
64
|
subject { policy.errors }
|
65
65
|
|
66
|
-
its(:class)
|
67
|
-
its(:
|
66
|
+
its(:class) { is_expected.to eq Tram::Policy::Errors }
|
67
|
+
its(:scope) { is_expected.to eql policy.scope }
|
68
68
|
end
|
69
69
|
|
70
70
|
describe "#valid?" do
|
data/tram-policy.gemspec
CHANGED
@@ -1,9 +1,9 @@
|
|
1
1
|
Gem::Specification.new do |gem|
|
2
2
|
gem.name = "tram-policy"
|
3
|
-
gem.version = "1.0
|
3
|
+
gem.version = "2.1.0"
|
4
4
|
gem.author = ["Viktor Sokolov (gzigzigzeo)", "Andrew Kozin (nepalez)"]
|
5
5
|
gem.email = "andrew.kozin@gmail.com"
|
6
|
-
gem.homepage = "https://github.com/tram/tram-policy"
|
6
|
+
gem.homepage = "https://github.com/tram-rb/tram-policy"
|
7
7
|
gem.summary = "Policy Object Pattern"
|
8
8
|
gem.license = "MIT"
|
9
9
|
|
@@ -14,7 +14,7 @@ Gem::Specification.new do |gem|
|
|
14
14
|
|
15
15
|
gem.required_ruby_version = ">= 2.3"
|
16
16
|
|
17
|
-
gem.add_runtime_dependency "dry-initializer", "
|
17
|
+
gem.add_runtime_dependency "dry-initializer", "> 2", "< 4"
|
18
18
|
gem.add_runtime_dependency "i18n", "~> 1.0"
|
19
19
|
|
20
20
|
gem.add_development_dependency "rake", "> 10"
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: tram-policy
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0
|
4
|
+
version: 2.1.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Viktor Sokolov (gzigzigzeo)
|
@@ -9,22 +9,28 @@ authors:
|
|
9
9
|
autorequire:
|
10
10
|
bindir: bin
|
11
11
|
cert_chain: []
|
12
|
-
date:
|
12
|
+
date: 2021-11-30 00:00:00.000000000 Z
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: dry-initializer
|
16
16
|
requirement: !ruby/object:Gem::Requirement
|
17
17
|
requirements:
|
18
|
-
- - "
|
18
|
+
- - ">"
|
19
|
+
- !ruby/object:Gem::Version
|
20
|
+
version: '2'
|
21
|
+
- - "<"
|
19
22
|
- !ruby/object:Gem::Version
|
20
|
-
version: '
|
23
|
+
version: '4'
|
21
24
|
type: :runtime
|
22
25
|
prerelease: false
|
23
26
|
version_requirements: !ruby/object:Gem::Requirement
|
24
27
|
requirements:
|
25
|
-
- - "
|
28
|
+
- - ">"
|
29
|
+
- !ruby/object:Gem::Version
|
30
|
+
version: '2'
|
31
|
+
- - "<"
|
26
32
|
- !ruby/object:Gem::Version
|
27
|
-
version: '
|
33
|
+
version: '4'
|
28
34
|
- !ruby/object:Gem::Dependency
|
29
35
|
name: i18n
|
30
36
|
requirement: !ruby/object:Gem::Requirement
|
@@ -154,7 +160,7 @@ files:
|
|
154
160
|
- spec/tram/policy/validation_error_spec.rb
|
155
161
|
- spec/tram/policy_spec.rb
|
156
162
|
- tram-policy.gemspec
|
157
|
-
homepage: https://github.com/tram/tram-policy
|
163
|
+
homepage: https://github.com/tram-rb/tram-policy
|
158
164
|
licenses:
|
159
165
|
- MIT
|
160
166
|
metadata: {}
|
@@ -173,8 +179,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
173
179
|
- !ruby/object:Gem::Version
|
174
180
|
version: '0'
|
175
181
|
requirements: []
|
176
|
-
|
177
|
-
rubygems_version: 2.6.14
|
182
|
+
rubygems_version: 3.1.6
|
178
183
|
signing_key:
|
179
184
|
specification_version: 4
|
180
185
|
summary: Policy Object Pattern
|