pears 0.0.2 → 0.0.6

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: 2197266157a485a41edd916bd9c6b65c02bfe87853c3b92feb1331420c47b3b6
4
- data.tar.gz: d8dfd5c144124e3f4a218ba9a179c42b0f0567454ecbcf4e11bfe83a0e1f9719
3
+ metadata.gz: 645ae89efe6ddeadbdad1d0e7a7e5688c58b62a747048b541b94ef10e9f2026a
4
+ data.tar.gz: 3baa65f99f31f0229de5c500c5dcc373532fe793453c29f4ab5ae978de43f4a6
5
5
  SHA512:
6
- metadata.gz: 6ea3a304658ceeecb54b49db406ec8d612c1b982ba37bc049e3ba731a6892ce23fae8615a4692d1c2fd83016fe692eb33bb743af23cd32a2e258c94d2155c3c2
7
- data.tar.gz: 5bcc80d0a9b26f28ced499dcc0463fe613111a7e67a13726834c6a59512add3baa8c64d9fbe955a3f933f4642c02247870af229b848ffb4c388b6ba68f83ea64
6
+ metadata.gz: 57dc635116560ce42ad9c71e9f23134f61ae25040f59d0edc1ebfbef9654dd18305f4c49e86b5026a312c7a79237e49b48233fb564063d82d2bdef44e1d73c7e
7
+ data.tar.gz: 3897e7f03640897df2aa77709fc2fb494ec9eab1c4bf1642f89d25adf99d86605c9793314c9c94ace252293bc9fa484b2d65297a1662eefbd31cfc95b5b1e184
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- pears (0.1.0)
4
+ pears (0.0.6)
5
5
  activesupport
6
6
  dry-configurable (>= 0.13.0)
7
7
  redis
@@ -9,7 +9,7 @@ PATH
9
9
  GEM
10
10
  remote: https://rubygems.org/
11
11
  specs:
12
- activesupport (6.1.4.1)
12
+ activesupport (6.1.4.3)
13
13
  concurrent-ruby (~> 1.0, >= 1.0.2)
14
14
  i18n (>= 1.6, < 2)
15
15
  minitest (>= 5.1)
@@ -25,7 +25,7 @@ GEM
25
25
  concurrent-ruby (~> 1.0)
26
26
  i18n (1.8.11)
27
27
  concurrent-ruby (~> 1.0)
28
- minitest (5.14.4)
28
+ minitest (5.15.0)
29
29
  rake (13.0.6)
30
30
  redis (4.5.1)
31
31
  rspec (3.10.0)
@@ -1,44 +1,53 @@
1
1
  require 'active_support/core_ext/module'
2
2
 
3
3
  module Pears
4
- module Providers
4
+ module Provider
5
5
  class Builder
6
+ # Evil meta programming.
7
+ def self.enable_provider(provider, yielder: false)
8
+ method_name = provider.name.split('::').last.underscore.to_sym
9
+ if yielder
10
+ define_method(method_name) do |*args, &block|
11
+ pr = provider.new(builder: self, &block)
12
+ push pr
13
+ pr
14
+ end
15
+ else
16
+ define_method(method_name) do |*args, **opts, &block|
17
+ pr = provider.new(*args, **opts, &block)
18
+ push pr
19
+ pr
20
+ end
21
+ end
22
+ end
23
+
24
+ # define Providers
25
+ enable_provider LocalFile
26
+ enable_provider RemoteFile
27
+ enable_provider Subscription, yielder: true
28
+
6
29
  delegate :name, to: :subject
7
30
 
8
31
  def initialize(subject)
9
32
  @subject = subject
10
33
  end
11
34
 
12
- def hash
13
- raise 'not yet implemented'
14
- end
15
-
16
- def loco
17
- raise 'not yet implemented'
18
- end
19
-
20
- def env
21
- raise 'not yet implemented'
22
- end
23
-
24
- def local_file(file_path)
25
- register Provider::LocalFile.new(file_path)
26
- end
27
-
28
- def remote_file(file_url)
29
- register Provider::RemoteFile.new(file_url)
35
+ def freeze_layers
36
+ @skip_push = true
37
+ yield
38
+ @skip_push = false
30
39
  end
31
40
 
32
- def subscription &block
33
- register Provider::Subscription.new(@subject.name, &block)
41
+ def subject_name
42
+ @subject.name
34
43
  end
35
44
 
36
45
  private
37
46
 
38
- def register provider
47
+ def push provider
39
48
  return provider unless @subject.is_a? Subject
40
49
 
41
- @subject.push_layer provider
50
+ @subject.push_layer provider unless @skip_push
42
51
  end
43
52
  end
44
53
  end
@@ -9,6 +9,7 @@ module Pears
9
9
  private
10
10
 
11
11
  def fetch_from_loco(api_key, url)
12
+ raise "Not yet implemented"
12
13
  # Get config from loco
13
14
  end
14
15
  end
@@ -1,27 +1,41 @@
1
1
  # frozen_string_literal: true
2
2
  require 'redis'
3
3
 
4
+
4
5
  module Pears
5
6
  module Provider
6
7
  # Config using redis subscription. This updates automatically upon Redis
7
8
  # channel updates.
9
+ # This class would register as "alternative classes with different interfaces".
10
+ # I ought to clean this up and maybe make "triggers" a different entity
11
+ # from a provider available in the builder.
12
+
8
13
  class Subscription < Base
9
14
  attr_reader :subscription
10
-
11
- def initialize(channel,
15
+ def initialize(channel=nil,
12
16
  redis_host: Pears.config.redis_host,
17
+ **opts,
13
18
  &fetcher)
19
+ @builder = opts[:builder] || Builder.new(nil)
14
20
  @channel = channel
21
+
22
+ # Fetcher is a "Provider" of some sort.
15
23
  @fetcher = fetcher
16
24
 
25
+ # Setup redis subscription
17
26
  establish_connection(redis_host)
18
- subscribe
19
27
  reload
28
+ subscribe
29
+ end
30
+
31
+ def channel
32
+ @channel ||= @builder.subject_name
20
33
  end
21
34
 
22
35
  def reload
23
- @data = @fetcher.call(Pears::Providers::Builder.new(self))
24
- .data
36
+ @builder.freeze_layers do
37
+ @data = @fetcher.call.data
38
+ end
25
39
  end
26
40
 
27
41
  # This seems a bit "rough" of an approach. we should check if
@@ -9,5 +9,8 @@ require_relative "provider/builder"
9
9
 
10
10
  module Pears
11
11
  module Provider
12
+ def enable(provider, with_block: false)
13
+ Builder.enable
14
+ end
12
15
  end
13
16
  end
data/lib/pears/subject.rb CHANGED
@@ -1,3 +1,5 @@
1
+ require 'active_support/core_ext/hash/indifferent_access'
2
+
1
3
  module Pears
2
4
  # A subject is a collection of settings.
3
5
  # You could different Pears::Subjects in your application for different parts
@@ -23,6 +25,10 @@ module Pears
23
25
  project.has_key? key
24
26
  end
25
27
 
28
+ def dig(*args)
29
+ project.dig(*args)
30
+ end
31
+
26
32
  def push_layer(layer)
27
33
  @layers << layer
28
34
  end
@@ -31,7 +37,7 @@ module Pears
31
37
  def project
32
38
  layers.reverse.reduce(Hash.new) do |hash, layer|
33
39
  hash.deep_merge(layer.data)
34
- end
40
+ end.with_indifferent_access
35
41
  end
36
42
 
37
43
  private
data/lib/pears/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Pears
4
- VERSION = "0.0.2"
4
+ VERSION = "0.0.6"
5
5
  end
data/lib/pears.rb CHANGED
@@ -14,11 +14,10 @@ module Pears
14
14
  @subjects ||= []
15
15
  end
16
16
 
17
-
18
17
  # This is the main way of locating a subject.
19
18
  def self.subject(name)
20
- Subject.new(name: name).tap do |subject|
21
- builder = Providers::Builder.new(subject)
19
+ Subject.new(name).tap do |subject|
20
+ builder = Provider::Builder.new(subject)
22
21
  yield(builder)
23
22
  end
24
23
  end
data/pears-0.0.5.gem ADDED
Binary file
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: pears
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.2
4
+ version: 0.0.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - Steven Kemp
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-12-10 00:00:00.000000000 Z
11
+ date: 2021-12-15 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: dry-configurable
@@ -96,6 +96,7 @@ files:
96
96
  - lib/pears/provider/subscription.rb
97
97
  - lib/pears/subject.rb
98
98
  - lib/pears/version.rb
99
+ - pears-0.0.5.gem
99
100
  - pears.gemspec
100
101
  homepage: https://www.rubygems.com
101
102
  licenses: