deepstream 1.0.2 → 1.0.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: df8169bda63ee658320c41ca0f1dd64de4a587d2b072786d1bc8ab936c96708c
4
- data.tar.gz: 66648cc17ba621f33cbd9d7204f473201112adc309763331de39a723a665f342
3
+ metadata.gz: fb92438a6ee2d2ab7fe48104493f4007a1ca6b0f1716b8c6c362a2429099cb2d
4
+ data.tar.gz: 2b4a5dd03874f759869869869521c24d793a2b40216b6b1f010bcdcc1f45b4c9
5
5
  SHA512:
6
- metadata.gz: 0f67317f952de1c621942d12b37aab4dbb321c6b3fb00c81ecd22e8b1288f47b6b14f64d1081a871359a721b89f5e29c44f135ec4e3523336c3da28030a08568
7
- data.tar.gz: 629ec25bb730fc2392c12669a30a05ef0a19ea69c0567701a1db58eca8461ae36074bbfa13845f22ce5fb72cf8b09bfa657768777d48788e7b3e7007749936a9
6
+ metadata.gz: a87edb61bce878657d2f04bb4eb1d8e4634a968d27b530c61173c01f939656384e088a4a76197e1570afd01700d2b92a6eee14ae30d97175de194a95ce7c198b
7
+ data.tar.gz: 7f5eee48da30fa2160e0b9f1df1d1fdee08f4ec0427525bf6bcea310d8963e9fc30f0e3dd2d0f8d4af77689663c50b468f8cf81be6bc242cffcb6e4585249614
data/README.md CHANGED
@@ -79,6 +79,9 @@ foo.data
79
79
  foo.keys
80
80
  # get records from the list
81
81
  foo.all
82
+ # callbacks
83
+ foo.on(:added) { |record| }
84
+ foo.on(:removed) { |record| }
82
85
  ```
83
86
 
84
87
 
data/deepstream.gemspec CHANGED
@@ -4,7 +4,7 @@ $LOAD_PATH.unshift(lib) unless $LOAD_PATH.include?(lib)
4
4
 
5
5
  Gem::Specification.new do |spec|
6
6
  spec.name = "deepstream"
7
- spec.version = "1.0.2"
7
+ spec.version = "1.0.7"
8
8
  spec.authors = ["Currency-One S.A."]
9
9
  spec.email = ["ruby@currency-one.com"]
10
10
 
@@ -3,6 +3,18 @@ module Async
3
3
  class Client < ::Protocol::HTTP::Middleware
4
4
  include ::Protocol::WebSocket::Headers
5
5
 
6
+ def self.open(endpoint, *args, &block)
7
+ client = self.new(HTTP::Client.new(endpoint, *args), mask: true)
8
+
9
+ return client unless block_given?
10
+
11
+ begin
12
+ yield client
13
+ ensure
14
+ client.close
15
+ end
16
+ end
17
+
6
18
  def self.connect(endpoint, *args, **options, &block)
7
19
  self.open(endpoint, *args) do |client|
8
20
  connection = client.connect(endpoint.path, **options)
@@ -32,14 +44,3 @@ module Async
32
44
  end
33
45
  end
34
46
  end
35
-
36
- module Protocol
37
- module WebSocket
38
- class TextFrame
39
-
40
- def unpack
41
- encoded_readed_string = super.encode(Encoding::UTF_8)
42
- end
43
- end
44
- end
45
- end
@@ -1,4 +1,5 @@
1
1
  module Deepstream
2
2
  class UnknownTopic < StandardError; end
3
3
  class UnknownAction < StandardError; end
4
+ class UnknownListCallback < StandardError; end
4
5
  end
@@ -46,7 +46,7 @@ module Deepstream
46
46
  url.tap do |url|
47
47
  url.prepend(SCHEME) unless url.start_with?(/ws(s|)\:\/\//)
48
48
  url.concat(":#{DEFAULT_PORT}") unless url[/\:\d+/]
49
- url.concat("/#{DEFAULT_PATH}") unless url[/\/\w+$/]
49
+ url.concat("/#{DEFAULT_PATH}") unless url[/:\d+\/\S+$/]
50
50
  end
51
51
  end
52
52
 
@@ -1,16 +1,21 @@
1
1
  require_relative './record'
2
+ require_relative './exceptions'
2
3
 
3
4
  module Deepstream
4
5
  class List < Record
6
+ LIST_CALLBACKS = %i{added removed}
7
+
5
8
  def initialize(*args)
6
9
  super
7
10
  @data = []
11
+ @handlers = {}
8
12
  end
9
13
 
10
14
  def add(record_name)
11
15
  unless @data.include?(record_name)
12
16
  @data << record_name
13
17
  set
18
+ notify_listeners(:removed, record_name)
14
19
  end
15
20
  rescue => e
16
21
  @client.on_exception(e)
@@ -20,13 +25,14 @@ module Deepstream
20
25
  @version = version.to_i
21
26
  data = JSON.parse(data)
22
27
  if data.is_a?(Array)
23
- @data.concat(data).uniq!
28
+ set_new_data (@data + data).uniq
24
29
  set if @data.size > data.size
25
30
  end
26
31
  end
27
32
 
28
33
  def remove(record_name)
29
34
  set if @data.delete(record_name)
35
+ notify_listeners(:removed, record_name)
30
36
  end
31
37
 
32
38
  def keys
@@ -43,10 +49,53 @@ module Deepstream
43
49
  @is_reinitializing = false
44
50
  end
45
51
 
52
+ def update(version, data)
53
+ @version = version.to_i
54
+ set_new_data JSON.parse(data)
55
+ rescue => e
56
+ @client.on_exception(e)
57
+ end
58
+
59
+ def on(cb_name, &block)
60
+ unless LIST_CALLBACKS.include?(cb_name)
61
+ raise(UnknownListCallback, "Uknown callback name: #{cb_name}. Must be one of: #{LIST_CALLBACKS}")
62
+ end
63
+ (@handlers[cb_name] ||= []).push(block)
64
+ nil
65
+ end
66
+
67
+ def off(cb_name, &block)
68
+ if block_given?
69
+ @handlers[cb_name].delete block
70
+ elsif cb_name
71
+ @handlers[cb_name] = []
72
+ else
73
+ @handlers = {}
74
+ end
75
+ nil
76
+ end
77
+
46
78
  private
47
79
 
48
80
  def set
49
81
  @client.send_message(TOPIC::RECORD, ACTION::UPDATE, @name, (@version += 1), @data.to_json) if @version
50
82
  end
83
+
84
+ def set_new_data(new_data)
85
+ (@data - new_data).each { |uid| notify_listeners(:removed, uid) }
86
+ (new_data - @data).each { |uid| notify_listeners(:added, uid) }
87
+ @data = new_data
88
+ end
89
+
90
+ def notify_listeners(cb_name, uid)
91
+ (@handlers[cb_name] || []).each do |proc|
92
+ record = @client.get(uid)
93
+ if record.__version
94
+ proc.call(record)
95
+ else
96
+ record.when_ready(&proc)
97
+ end
98
+ end
99
+ end
51
100
  end
52
101
  end
@@ -4,6 +4,8 @@ require_relative './helpers'
4
4
 
5
5
  module Deepstream
6
6
  class Record
7
+ attr_reader :data
8
+
7
9
  def initialize(client, name)
8
10
  @client = client
9
11
  @name = name
@@ -12,6 +14,15 @@ module Deepstream
12
14
  @is_reinitializing = false
13
15
  @data_cache = {}
14
16
  @client.send_message(TOPIC::RECORD, ACTION::CREATEORREAD, @name)
17
+ @ready_callback = nil
18
+ end
19
+
20
+ def __version
21
+ @version
22
+ end
23
+
24
+ def __name
25
+ @name
15
26
  end
16
27
 
17
28
  def reset_version
@@ -60,8 +71,16 @@ module Deepstream
60
71
  @client.on_exception(e)
61
72
  end
62
73
 
74
+ def when_ready(&block)
75
+ @ready_callback = block
76
+ end
77
+
63
78
  def read(version, data)
64
79
  update(version, data)
80
+ if @ready_callback
81
+ @ready_callback.call(self)
82
+ @ready_callback = nil
83
+ end
65
84
  end
66
85
 
67
86
  def patch(version, path, value)
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: deepstream
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.0.2
4
+ version: 1.0.7
5
5
  platform: ruby
6
6
  authors:
7
7
  - Currency-One S.A.
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2021-01-19 00:00:00.000000000 Z
11
+ date: 2021-02-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: async