easy-settings 1.0.0 → 1.3.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.rdoc +1 -1
- data/docker-compose.yml +5 -0
- data/lib/easy-settings.rb +4 -1
- data/lib/easy-settings/env_source.rb +7 -13
- data/lib/easy-settings/path_source.rb +14 -6
- data/lib/easy-settings/struct.rb +3 -3
- data/lib/easy-settings/version.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: 742f94a5ea13b5a42e8e652f6b241880977efacf37b464da912c39ea28a11bec
|
4
|
+
data.tar.gz: 4ff117b32d32b3a180767cafbd106f4df0d5dbc69aa00183647e16f5a5e723d9
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3eda64f580f75b8ea81f79cae2b17e7bba85874f203a7b11a03dc9ae7231887ed4e21083624906c2174b0585e449d7d9d260701dce88de493bade556e6e31843
|
7
|
+
data.tar.gz: 7fc6687b0cd39502b95dd026a4b3429dec813bcbedc0e15b3ef9544239664d97508d4ebc1a25a3404640316ff8617eebdffc466250d42b126f2cc7b8e878f2c4
|
data/README.rdoc
CHANGED
data/docker-compose.yml
CHANGED
data/lib/easy-settings.rb
CHANGED
@@ -1,3 +1,6 @@
|
|
1
|
+
require "active_support"
|
2
|
+
require "active_support/core_ext/module/delegation"
|
3
|
+
|
1
4
|
require "easy-settings/version"
|
2
5
|
require "easy-settings/struct"
|
3
6
|
require "easy-settings/env_source"
|
@@ -7,7 +10,7 @@ require "easy-settings/yaml_source"
|
|
7
10
|
class EasySettings
|
8
11
|
delegate :respond_to?, to: :@data
|
9
12
|
|
10
|
-
def initialize(sources
|
13
|
+
def initialize(sources: [], fail_on_missing: true)
|
11
14
|
@sources = sources
|
12
15
|
@fail_on_missing = fail_on_missing
|
13
16
|
reload!
|
@@ -1,27 +1,21 @@
|
|
1
|
-
require "easy-settings/
|
1
|
+
require "easy-settings/path_source"
|
2
|
+
require "active_support/core_ext/object"
|
2
3
|
|
3
|
-
class EasySettings::EnvSource
|
4
|
-
attr_reader :prefix
|
4
|
+
class EasySettings::EnvSource < EasySettings::PathSource
|
5
|
+
attr_reader :prefix
|
5
6
|
|
6
7
|
def initialize(prefix, separator: "__", converter: :downcase, parse_values: true)
|
7
8
|
@prefix = prefix
|
8
|
-
|
9
|
-
@converter = converter
|
10
|
-
@parse_values = parse_values
|
9
|
+
super(nil, separator: separator, converter: converter, parse_values: parse_values)
|
11
10
|
end
|
12
11
|
|
13
12
|
def load
|
14
13
|
{}.tap do |data|
|
15
14
|
ENV.each do |variable, value|
|
16
15
|
keys = variable.to_s.split(separator)
|
17
|
-
next
|
16
|
+
next if prefix.present? && keys.shift != prefix
|
18
17
|
|
19
|
-
keys
|
20
|
-
|
21
|
-
leaf = keys[0...-1].inject(data){ |h, key| h[key] ||= {} }
|
22
|
-
leaf[keys.last] = parse_values ? EasySettings::Coercion.new(value).run : value
|
23
|
-
rescue NoMethodError => e
|
24
|
-
raise "Invalid name converter: #{converter}"
|
18
|
+
assign_value(data, keys, value)
|
25
19
|
end
|
26
20
|
end
|
27
21
|
end
|
@@ -19,13 +19,21 @@ class EasySettings::PathSource
|
|
19
19
|
value = File.read(path).strip
|
20
20
|
|
21
21
|
keys = variable.to_s.split(separator)
|
22
|
-
keys
|
23
|
-
|
24
|
-
leaf = keys[0...-1].inject(data){ |h, key| h[key] ||= {} }
|
25
|
-
leaf[keys.last] = parse_values ? EasySettings::Coercion.new(value).run : value
|
26
|
-
rescue NoMethodError => e
|
27
|
-
raise "Invalid name converter: #{converter}"
|
22
|
+
assign_value(data, keys, value)
|
28
23
|
end
|
29
24
|
end
|
30
25
|
end
|
26
|
+
|
27
|
+
def assign_value(data, keys, value)
|
28
|
+
keys.map! do |key|
|
29
|
+
next key.to_i if key =~ /^\d+/
|
30
|
+
next key.send(converter) if converter
|
31
|
+
key
|
32
|
+
rescue NoMethodError => e
|
33
|
+
raise "Invalid name converter: #{converter}"
|
34
|
+
end
|
35
|
+
|
36
|
+
leaf = keys[0...-1].each_with_index.inject(data){ |h, (key, i)| h[key] ||= keys[i + 1].is_a?(Integer) ? [] : {} }
|
37
|
+
leaf[keys.last] = parse_values ? EasySettings::Coercion.new(value).run : value
|
38
|
+
end
|
31
39
|
end
|
data/lib/easy-settings/struct.rb
CHANGED
@@ -24,15 +24,15 @@ class EasySettings::Struct
|
|
24
24
|
end
|
25
25
|
|
26
26
|
def [](property)
|
27
|
-
@properties.fetch(property){ raise_unknown_property(property) }
|
27
|
+
@properties.fetch(property.to_s){ raise_unknown_property(property) }
|
28
28
|
end
|
29
29
|
|
30
30
|
def []=(property, value)
|
31
|
-
@properties[property] = value
|
31
|
+
@properties[property.to_s] = value
|
32
32
|
end
|
33
33
|
|
34
34
|
def try(property)
|
35
|
-
@properties[property]
|
35
|
+
@properties[property.to_s]
|
36
36
|
end
|
37
37
|
|
38
38
|
def to_h
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: easy-settings
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.
|
4
|
+
version: 1.3.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Corin Langosch
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-11-11 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rspec
|