artery 1.2.0 → 1.2.1
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:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: fd74a0468234a04d072dc0235885426aff27b04353a10f3a32176ada5ebd932e
|
|
4
|
+
data.tar.gz: 70193e8d9f5a01ac73157cf4f105252ed66e59a211b169e10b5e5e95a618b5d2
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: f93909d8a746b73ac81fcf4cecb2e92d6b7c5b761b16a1d8c244527b18f460ad21498ac5b2556f12ad3cafc75eca7a69724447540d6a5c1a2bb086d0a3bf660b
|
|
7
|
+
data.tar.gz: 0a006ed60df6714bcb0459fb34106ef970c760eb58895437b0ac8ca08303ddd6c15559c657e7ce2353c9427621bd84c514102f0326de803b86e39e0249cc54ef
|
data/lib/artery/backend.rb
CHANGED
|
@@ -71,8 +71,9 @@ module Artery
|
|
|
71
71
|
response = JSON.parse(message).with_indifferent_access
|
|
72
72
|
|
|
73
73
|
if response.key?(:error)
|
|
74
|
-
handler.call :error, RequestError.new(uri, response,
|
|
75
|
-
|
|
74
|
+
handler.call :error, RequestError.new(uri, response,
|
|
75
|
+
request: { route: uri.to_route, data: data.to_json },
|
|
76
|
+
response: message)
|
|
76
77
|
else
|
|
77
78
|
handler.call :success, response
|
|
78
79
|
end
|
data/lib/artery/engine.rb
CHANGED
|
@@ -41,7 +41,7 @@ module Artery
|
|
|
41
41
|
end
|
|
42
42
|
|
|
43
43
|
artery[:subscriptions] ||= []
|
|
44
|
-
artery[:subscriptions].push Subscription.new(self, uri, **options
|
|
44
|
+
artery[:subscriptions].push Subscription.new(self, uri, **options, handler: handler)
|
|
45
45
|
end
|
|
46
46
|
|
|
47
47
|
def artery_watch_model(service:, model: nil, action: nil, **kwargs, &blk)
|
|
@@ -124,7 +124,8 @@ module Artery
|
|
|
124
124
|
|
|
125
125
|
updates = messages.map do |message|
|
|
126
126
|
upd = message.to_artery.merge('action' => message.action)
|
|
127
|
-
|
|
127
|
+
# WARNING: duplicated logic with `Subscription#handle`!
|
|
128
|
+
if %i[create update].include?(message.action.to_sym) &&
|
|
128
129
|
autoenrich_data &&
|
|
129
130
|
(attrs = autoenrich_data[message.data['uuid']])
|
|
130
131
|
upd['attributes'] = attrs
|
|
@@ -66,7 +66,8 @@ module Artery
|
|
|
66
66
|
data: data.to_json,
|
|
67
67
|
route: from
|
|
68
68
|
},
|
|
69
|
-
request: { data: get_data.to_json, route: get_uri.to_route },
|
|
69
|
+
request: { data: get_data.to_json, route: get_uri.to_route },
|
|
70
|
+
response: attributes.to_json)
|
|
70
71
|
Artery.handle_error error
|
|
71
72
|
end
|
|
72
73
|
|
|
@@ -74,12 +75,15 @@ module Artery
|
|
|
74
75
|
if e.message == 'not_found'
|
|
75
76
|
yield(:not_found)
|
|
76
77
|
else
|
|
77
|
-
error = Error.new(
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
78
|
+
error = Error.new(
|
|
79
|
+
"Failed to get #{get_uri.model} from #{get_uri.service} with uuid='#{data[:uuid]}': #{e.message}",
|
|
80
|
+
**e.artery_context,
|
|
81
|
+
subscription: {
|
|
82
|
+
subscriber: subscription.subscriber.to_s,
|
|
83
|
+
data: data.to_json,
|
|
84
|
+
route: from_uri.to_route
|
|
85
|
+
}
|
|
86
|
+
)
|
|
83
87
|
Artery.handle_error error
|
|
84
88
|
end
|
|
85
89
|
end
|
|
@@ -29,7 +29,8 @@ module Artery
|
|
|
29
29
|
end
|
|
30
30
|
|
|
31
31
|
def synchronize_updates_per_page
|
|
32
|
-
(options[:synchronize_updates].is_a?(Hash) && options[:synchronize_updates][:per_page]) ||
|
|
32
|
+
(options[:synchronize_updates].is_a?(Hash) && options[:synchronize_updates][:per_page]) ||
|
|
33
|
+
synchronization_per_page
|
|
33
34
|
end
|
|
34
35
|
|
|
35
36
|
def synchronize_updates_autoenrich?
|
|
@@ -132,7 +133,7 @@ module Artery
|
|
|
132
133
|
|
|
133
134
|
synchronization_transaction { handler.call(:synchronization, objects, page) }
|
|
134
135
|
|
|
135
|
-
if synchronization_per_page && objects.
|
|
136
|
+
if synchronization_per_page && objects.any?
|
|
136
137
|
synchronization_page_update!(page)
|
|
137
138
|
Artery.logger.debug "PAGE #{page} RECEIVED, WILL CONTINUE..."
|
|
138
139
|
should_continue = true
|
|
@@ -154,8 +155,11 @@ module Artery
|
|
|
154
155
|
|
|
155
156
|
on.error do |e|
|
|
156
157
|
synchronization_in_progress!(false)
|
|
157
|
-
error = Error.new
|
|
158
|
-
|
|
158
|
+
error = Error.new(
|
|
159
|
+
"Failed to get all objects #{uri.model} from #{uri.service} with " \
|
|
160
|
+
"scope='#{synchronization_scope}': #{e.message}",
|
|
161
|
+
**e.artery_context
|
|
162
|
+
)
|
|
159
163
|
Artery.handle_error error
|
|
160
164
|
end
|
|
161
165
|
end
|
data/lib/artery/version.rb
CHANGED
metadata
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: artery
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 1.2.
|
|
4
|
+
version: 1.2.1
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Sergey Gnuskov
|
|
@@ -10,33 +10,33 @@ cert_chain: []
|
|
|
10
10
|
date: 1980-01-02 00:00:00.000000000 Z
|
|
11
11
|
dependencies:
|
|
12
12
|
- !ruby/object:Gem::Dependency
|
|
13
|
-
name:
|
|
13
|
+
name: artery-browser
|
|
14
14
|
requirement: !ruby/object:Gem::Requirement
|
|
15
15
|
requirements:
|
|
16
16
|
- - "~>"
|
|
17
17
|
- !ruby/object:Gem::Version
|
|
18
|
-
version: '0.
|
|
18
|
+
version: '0.1'
|
|
19
19
|
type: :runtime
|
|
20
20
|
prerelease: false
|
|
21
21
|
version_requirements: !ruby/object:Gem::Requirement
|
|
22
22
|
requirements:
|
|
23
23
|
- - "~>"
|
|
24
24
|
- !ruby/object:Gem::Version
|
|
25
|
-
version: '0.
|
|
25
|
+
version: '0.1'
|
|
26
26
|
- !ruby/object:Gem::Dependency
|
|
27
|
-
name:
|
|
27
|
+
name: multiblock
|
|
28
28
|
requirement: !ruby/object:Gem::Requirement
|
|
29
29
|
requirements:
|
|
30
30
|
- - "~>"
|
|
31
31
|
- !ruby/object:Gem::Version
|
|
32
|
-
version: '0.
|
|
32
|
+
version: '0.2'
|
|
33
33
|
type: :runtime
|
|
34
34
|
prerelease: false
|
|
35
35
|
version_requirements: !ruby/object:Gem::Requirement
|
|
36
36
|
requirements:
|
|
37
37
|
- - "~>"
|
|
38
38
|
- !ruby/object:Gem::Version
|
|
39
|
-
version: '0.
|
|
39
|
+
version: '0.2'
|
|
40
40
|
- !ruby/object:Gem::Dependency
|
|
41
41
|
name: nats-pure
|
|
42
42
|
requirement: !ruby/object:Gem::Requirement
|