complex_config 0.17.0 → 0.19.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/.travis.yml +1 -1
- data/Rakefile +1 -1
- data/VERSION +1 -1
- data/complex_config.gemspec +15 -24
- data/lib/complex_config/plugins/uri.rb +1 -1
- data/lib/complex_config/provider.rb +5 -3
- data/lib/complex_config/settings.rb +22 -3
- data/lib/complex_config/version.rb +1 -1
- data/spec/complex_config/provider_spec.rb +2 -2
- data/spec/complex_config/settings_spec.rb +5 -0
- data/spec/config/config.yml +2 -0
- metadata +8 -8
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 4ff2b361ee9d3b06983e6ccdcc847a1ca17dd7b41cdf7bc45fc83bc0261b318c
|
4
|
+
data.tar.gz: a658135bbc6e28aaef43ec7ba14ec70e8cde6bcdf1a897ddae0c26abd1a5f0fb
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 750968741f4e6744525b091cd101d8e3344ded32f538e98a99f450c553de9b36e7f18d7275c1efacc4319634b85f78549107c1daa05eb24b560464043b0b02e0
|
7
|
+
data.tar.gz: 2f6a955ac2ee470429390784b2e886655556ac0c06a3a6d440357a295b62d155c4f8ce6622834a2724671cab5e9a4c28c74f46e05631523bb12fa84c0c96d1d0
|
data/.gitignore
CHANGED
data/.travis.yml
CHANGED
data/Rakefile
CHANGED
@@ -12,7 +12,7 @@ GemHadar do
|
|
12
12
|
executables 'complex_config'
|
13
13
|
test_dir 'spec'
|
14
14
|
ignore '.*.sw[pon]', 'pkg', 'Gemfile.lock', 'coverage', '.rvmrc',
|
15
|
-
'.AppleDouble', '.DS_Store', '.byebug_history', 'errors.lst'
|
15
|
+
'.AppleDouble', '.DS_Store', '.byebug_history', 'errors.lst', 'tags'
|
16
16
|
|
17
17
|
readme 'README.md'
|
18
18
|
title "#{name.camelize} -- configuration library"
|
data/VERSION
CHANGED
@@ -1 +1 @@
|
|
1
|
-
0.
|
1
|
+
0.19.0
|
data/complex_config.gemspec
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
# -*- encoding: utf-8 -*-
|
2
|
-
# stub: complex_config 0.
|
2
|
+
# stub: complex_config 0.19.0 ruby lib
|
3
3
|
|
4
4
|
Gem::Specification.new do |s|
|
5
5
|
s.name = "complex_config".freeze
|
6
|
-
s.version = "0.
|
6
|
+
s.version = "0.19.0"
|
7
7
|
|
8
8
|
s.required_rubygems_version = Gem::Requirement.new(">= 0".freeze) if s.respond_to? :required_rubygems_version=
|
9
9
|
s.require_paths = ["lib".freeze]
|
10
10
|
s.authors = ["Florian Frank".freeze]
|
11
|
-
s.date = "
|
11
|
+
s.date = "2021-01-05"
|
12
12
|
s.description = "This library allows you to access configuration files via a simple interface".freeze
|
13
13
|
s.email = "flori@ping.de".freeze
|
14
14
|
s.executables = ["complex_config".freeze]
|
@@ -17,34 +17,25 @@ Gem::Specification.new do |s|
|
|
17
17
|
s.homepage = "https://github.com/flori/complex_config".freeze
|
18
18
|
s.licenses = ["Apache-2.0".freeze]
|
19
19
|
s.rdoc_options = ["--title".freeze, "ComplexConfig -- configuration library".freeze, "--main".freeze, "README.md".freeze]
|
20
|
-
s.rubygems_version = "3.
|
20
|
+
s.rubygems_version = "3.2.3".freeze
|
21
21
|
s.summary = "configuration library".freeze
|
22
22
|
s.test_files = ["spec/complex_config/config_spec.rb".freeze, "spec/complex_config/encryption_spec.rb".freeze, "spec/complex_config/key_source_spec.rb".freeze, "spec/complex_config/plugins_spec.rb".freeze, "spec/complex_config/provider_spec.rb".freeze, "spec/complex_config/settings_spec.rb".freeze, "spec/complex_config/shortcuts_spec.rb".freeze, "spec/spec_helper.rb".freeze]
|
23
23
|
|
24
24
|
if s.respond_to? :specification_version then
|
25
25
|
s.specification_version = 4
|
26
|
+
end
|
26
27
|
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
else
|
37
|
-
s.add_dependency(%q<gem_hadar>.freeze, ["~> 1.9.1"])
|
38
|
-
s.add_dependency(%q<rake>.freeze, [">= 0"])
|
39
|
-
s.add_dependency(%q<simplecov>.freeze, [">= 0"])
|
40
|
-
s.add_dependency(%q<rspec>.freeze, [">= 0"])
|
41
|
-
s.add_dependency(%q<monetize>.freeze, [">= 0"])
|
42
|
-
s.add_dependency(%q<json>.freeze, [">= 0"])
|
43
|
-
s.add_dependency(%q<tins>.freeze, [">= 0"])
|
44
|
-
s.add_dependency(%q<mize>.freeze, ["~> 0.3", ">= 0.3.4"])
|
45
|
-
end
|
28
|
+
if s.respond_to? :add_runtime_dependency then
|
29
|
+
s.add_development_dependency(%q<gem_hadar>.freeze, ["~> 1.11.0"])
|
30
|
+
s.add_development_dependency(%q<rake>.freeze, [">= 0"])
|
31
|
+
s.add_development_dependency(%q<simplecov>.freeze, [">= 0"])
|
32
|
+
s.add_development_dependency(%q<rspec>.freeze, [">= 0"])
|
33
|
+
s.add_development_dependency(%q<monetize>.freeze, [">= 0"])
|
34
|
+
s.add_runtime_dependency(%q<json>.freeze, [">= 0"])
|
35
|
+
s.add_runtime_dependency(%q<tins>.freeze, [">= 0"])
|
36
|
+
s.add_runtime_dependency(%q<mize>.freeze, ["~> 0.3", ">= 0.3.4"])
|
46
37
|
else
|
47
|
-
s.add_dependency(%q<gem_hadar>.freeze, ["~> 1.
|
38
|
+
s.add_dependency(%q<gem_hadar>.freeze, ["~> 1.11.0"])
|
48
39
|
s.add_dependency(%q<rake>.freeze, [">= 0"])
|
49
40
|
s.add_dependency(%q<simplecov>.freeze, [">= 0"])
|
50
41
|
s.add_dependency(%q<rspec>.freeze, [">= 0"])
|
@@ -65,7 +65,7 @@ class ComplexConfig::Provider
|
|
65
65
|
end
|
66
66
|
|
67
67
|
def config_dir
|
68
|
-
@config_dir || (defined?(Rails) && Rails.root || Pathname.pwd) + 'config'
|
68
|
+
@config_dir || (defined?(Rails) && Rails.respond_to?(:root) && Rails.root || Pathname.pwd) + 'config'
|
69
69
|
end
|
70
70
|
|
71
71
|
def pathname(name)
|
@@ -106,7 +106,7 @@ class ComplexConfig::Provider
|
|
106
106
|
shared = shared.to_h
|
107
107
|
settings.each do |key, value|
|
108
108
|
if value.is_a? ComplexConfig::Settings
|
109
|
-
value.
|
109
|
+
value.attributes_update_if_nil(shared)
|
110
110
|
elsif value.nil?
|
111
111
|
settings[key] = ComplexConfig::Settings.build(nil, shared.dup)
|
112
112
|
end
|
@@ -176,7 +176,9 @@ class ComplexConfig::Provider
|
|
176
176
|
end
|
177
177
|
|
178
178
|
def env
|
179
|
-
@env || defined?(Rails) && Rails.env
|
179
|
+
@env || defined?(Rails) && Rails.respond_to?(:env) && Rails.env ||
|
180
|
+
ENV['RAILS_ENV'] ||
|
181
|
+
'development'
|
180
182
|
end
|
181
183
|
|
182
184
|
attr_writer :env
|
@@ -76,6 +76,15 @@ class ComplexConfig::Settings < BasicObject
|
|
76
76
|
@table.update(other.table)
|
77
77
|
end
|
78
78
|
|
79
|
+
def attributes_update_if_nil(other)
|
80
|
+
unless other.is_a? self.class
|
81
|
+
other = self.class.from_hash(other)
|
82
|
+
end
|
83
|
+
@table.update(other.table) do |key, oldval, newval|
|
84
|
+
@table.key?(key) ? oldval : newval
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
79
88
|
def replace_attributes(hash)
|
80
89
|
@table = self.class.from_hash(hash).table
|
81
90
|
self
|
@@ -102,7 +111,7 @@ class ComplexConfig::Settings < BasicObject
|
|
102
111
|
end
|
103
112
|
|
104
113
|
def ==(other)
|
105
|
-
to_h == other.to_h
|
114
|
+
other.respond_to?(:to_h) && to_h == other.to_h
|
106
115
|
end
|
107
116
|
|
108
117
|
def to_yaml
|
@@ -124,7 +133,7 @@ class ComplexConfig::Settings < BasicObject
|
|
124
133
|
def to_s(pair_sep: ' = ', path_sep: ?.)
|
125
134
|
empty? and return self.class.name
|
126
135
|
pathes(path_sep: path_sep).inject('') do |result, (path, value)|
|
127
|
-
result
|
136
|
+
result + "#{path}#{pair_sep}#{value.inspect}\n"
|
128
137
|
end
|
129
138
|
end
|
130
139
|
|
@@ -178,7 +187,7 @@ class ComplexConfig::Settings < BasicObject
|
|
178
187
|
freeze
|
179
188
|
end
|
180
189
|
|
181
|
-
def
|
190
|
+
def attribute_get(name)
|
182
191
|
if !attribute_set?(name) and
|
183
192
|
value = ::ComplexConfig::Provider.apply_plugins(self, name)
|
184
193
|
then
|
@@ -188,6 +197,16 @@ class ComplexConfig::Settings < BasicObject
|
|
188
197
|
end
|
189
198
|
end
|
190
199
|
|
200
|
+
alias [] attribute_get
|
201
|
+
|
202
|
+
def attribute_get!(name)
|
203
|
+
if attribute_set?(name)
|
204
|
+
attribute_get(name)
|
205
|
+
else
|
206
|
+
raise ::ComplexConfig::AttributeMissing, "no attribute named #{name.inspect}"
|
207
|
+
end
|
208
|
+
end
|
209
|
+
|
191
210
|
def []=(name, value)
|
192
211
|
@table[name.to_sym] = value
|
193
212
|
end
|
@@ -314,8 +314,8 @@ RSpec.describe ComplexConfig::Provider do
|
|
314
314
|
|
315
315
|
it 'can share values' do
|
316
316
|
expect(described_class['config'].development.shared).to eq true
|
317
|
-
expect(described_class['config'].test.shared).to eq
|
318
|
-
expect(described_class['config'].staging.shared).to eq
|
317
|
+
expect(described_class['config'].test.shared).to eq nil
|
318
|
+
expect(described_class['config'].staging.shared).to eq false
|
319
319
|
end
|
320
320
|
end
|
321
321
|
end
|
@@ -133,6 +133,11 @@ EOT
|
|
133
133
|
expect(settings.foo.baz?).to be_falsy
|
134
134
|
end
|
135
135
|
|
136
|
+
it 'can trigger exception on attribute get' do
|
137
|
+
expect(settings.foo.attribute_get!(:bar)).to be_truthy
|
138
|
+
expect { settings.foo.attribute_get!(:baz) }.to raise_error ComplexConfig::AttributeMissing
|
139
|
+
end
|
140
|
+
|
136
141
|
it 'handles arrays correctly' do
|
137
142
|
settings = described_class[ary: [ 1, { hsh: 2 }, 3 ]]
|
138
143
|
expect(settings.to_h).to eq(ary: [ 1, { hsh: 2 }, 3 ])
|
data/spec/config/config.yml
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: complex_config
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.19.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Florian Frank
|
8
|
-
autorequire:
|
8
|
+
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2021-01-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: gem_hadar
|
@@ -16,14 +16,14 @@ dependencies:
|
|
16
16
|
requirements:
|
17
17
|
- - "~>"
|
18
18
|
- !ruby/object:Gem::Version
|
19
|
-
version: 1.
|
19
|
+
version: 1.11.0
|
20
20
|
type: :development
|
21
21
|
prerelease: false
|
22
22
|
version_requirements: !ruby/object:Gem::Requirement
|
23
23
|
requirements:
|
24
24
|
- - "~>"
|
25
25
|
- !ruby/object:Gem::Version
|
26
|
-
version: 1.
|
26
|
+
version: 1.11.0
|
27
27
|
- !ruby/object:Gem::Dependency
|
28
28
|
name: rake
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -200,7 +200,7 @@ homepage: https://github.com/flori/complex_config
|
|
200
200
|
licenses:
|
201
201
|
- Apache-2.0
|
202
202
|
metadata: {}
|
203
|
-
post_install_message:
|
203
|
+
post_install_message:
|
204
204
|
rdoc_options:
|
205
205
|
- "--title"
|
206
206
|
- ComplexConfig -- configuration library
|
@@ -219,8 +219,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
219
219
|
- !ruby/object:Gem::Version
|
220
220
|
version: '0'
|
221
221
|
requirements: []
|
222
|
-
rubygems_version: 3.
|
223
|
-
signing_key:
|
222
|
+
rubygems_version: 3.2.3
|
223
|
+
signing_key:
|
224
224
|
specification_version: 4
|
225
225
|
summary: configuration library
|
226
226
|
test_files:
|