peatio-bitgo 2.6.1 → 2.6.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: 6fd69cb9355753e4b4dfcd36af40b937c4dbf6b673e565ee2263dafd0f02dc97
4
- data.tar.gz: 073411c6f80b338c7aafed028cf3ab13b4570bb825eda0c39c9ff6a6106af666
3
+ metadata.gz: 71849263a007093ed7c9c53d013db6491856d5ea004017d060bec892c4a271fa
4
+ data.tar.gz: 10ee3a2cd730999d82bf904c24175e7d2a14a9fa120f12840131f705dda39a6a
5
5
  SHA512:
6
- metadata.gz: 7381d4c8ee6d975024a25184067ef83e77cb41cf541a21d2d7acb289b78747bc26f4ac377aed951ac61ff4bf1c60f2e95e6ad1272e2f9840ef3b8a7ba9573c10
7
- data.tar.gz: 3df1fcd729d750b4fb37afb44b054a7a19e7d36c129786561a6832b7095dbeabd84796f331fcb1a11fe1721707c7647666bb6a6019be1f14842b3b27048895a1
6
+ metadata.gz: afb277f1e26cf4f8de413545c9c433dc6225f5f22ea87190d268aa1b109fb0e1bdc477c2fbc3acca75dee38f1ede75cd6f995d984c4006a960dedab0e22b5a2a
7
+ data.tar.gz: 4f2b8fc5fe38426fbe2f6c2ec214bad40bd8430302b095758529f9c07ac6be0cbd102509a119874a3eae529bae35e145e60025216eb46cbd7c7827ec8a75dc09
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- peatio-bitgo (2.6.1)
4
+ peatio-bitgo (2.6.6)
5
5
  activesupport (~> 5.2.3)
6
6
  better-faraday (~> 1.0.5)
7
7
  faraday (~> 0.17)
@@ -12,35 +12,35 @@ PATH
12
12
  GEM
13
13
  remote: https://rubygems.org/
14
14
  specs:
15
- activemodel (5.2.4.2)
16
- activesupport (= 5.2.4.2)
17
- activesupport (5.2.4.2)
15
+ activemodel (5.2.5)
16
+ activesupport (= 5.2.5)
17
+ activesupport (5.2.5)
18
18
  concurrent-ruby (~> 1.0, >= 1.0.2)
19
19
  i18n (>= 0.7, < 2)
20
20
  minitest (~> 5.1)
21
21
  tzinfo (~> 1.1)
22
22
  addressable (2.7.0)
23
23
  public_suffix (>= 2.0.2, < 5.0)
24
- amq-protocol (2.3.1)
24
+ amq-protocol (2.3.2)
25
25
  amqp (1.8.0)
26
26
  amq-protocol (>= 2.2.0)
27
27
  eventmachine
28
28
  better-faraday (1.0.8)
29
29
  activesupport (>= 4.0, < 6.0)
30
30
  faraday (~> 0.12)
31
- bunny (2.15.0)
31
+ bunny (2.17.0)
32
32
  amq-protocol (~> 2.3, >= 2.3.1)
33
- byebug (11.1.1)
34
- clamp (1.3.1)
35
- coderay (1.1.2)
36
- concurrent-ruby (1.1.6)
37
- connection_pool (2.2.2)
33
+ byebug (11.1.3)
34
+ clamp (1.3.2)
35
+ coderay (1.1.3)
36
+ concurrent-ruby (1.1.8)
37
+ connection_pool (2.2.5)
38
38
  cookiejar (0.3.3)
39
39
  crack (0.4.3)
40
40
  safe_yaml (~> 1.0.0)
41
41
  daemons (1.3.1)
42
- diff-lcs (1.3)
43
- em-http-request (1.1.5)
42
+ diff-lcs (1.4.4)
43
+ em-http-request (1.1.7)
44
44
  addressable (>= 2.3.4)
45
45
  cookiejar (!= 0.3.1)
46
46
  em-socksify (>= 0.3)
@@ -50,40 +50,40 @@ GEM
50
50
  eventmachine (>= 1.0.0.beta.4)
51
51
  em-synchrony (1.0.6)
52
52
  eventmachine (>= 1.0.0.beta.1)
53
- em-websocket (0.5.1)
53
+ em-websocket (0.5.2)
54
54
  eventmachine (>= 0.12.9)
55
55
  http_parser.rb (~> 0.6.0)
56
56
  eventmachine (1.2.7)
57
- faraday (0.17.3)
57
+ faraday (0.17.4)
58
58
  multipart-post (>= 1.2, < 3)
59
59
  faraday_middleware (0.13.1)
60
60
  faraday (>= 0.7.4, < 1.0)
61
- faye (1.2.5)
61
+ faye (1.4.0)
62
62
  cookiejar (>= 0.3.0)
63
- em-http-request (>= 0.3.0)
63
+ em-http-request (>= 1.1.6)
64
64
  eventmachine (>= 0.12.0)
65
- faye-websocket (>= 0.9.1)
65
+ faye-websocket (>= 0.11.0)
66
66
  multi_json (>= 1.0.0)
67
67
  rack (>= 1.0.0)
68
68
  websocket-driver (>= 0.5.1)
69
- faye-websocket (0.10.9)
69
+ faye-websocket (0.11.0)
70
70
  eventmachine (>= 0.12.0)
71
71
  websocket-driver (>= 0.5.1)
72
72
  hashdiff (1.0.1)
73
73
  http_parser.rb (0.6.0)
74
- i18n (1.8.2)
74
+ i18n (1.8.10)
75
75
  concurrent-ruby (~> 1.0)
76
- jwt (2.2.1)
76
+ jwt (2.2.2)
77
77
  memoist (0.16.2)
78
78
  method_source (1.0.0)
79
- minitest (5.14.0)
79
+ minitest (5.14.4)
80
80
  mocha (1.11.2)
81
- multi_json (1.14.1)
81
+ multi_json (1.15.0)
82
82
  multipart-post (2.1.1)
83
83
  mysql2 (0.5.3)
84
84
  net-http-persistent (3.0.1)
85
85
  connection_pool (~> 2.2)
86
- peatio (2.4.4)
86
+ peatio (2.6.3)
87
87
  activemodel (> 5.2, <= 6.0.0)
88
88
  amqp
89
89
  bunny
@@ -97,44 +97,44 @@ GEM
97
97
  mysql2
98
98
  prometheus-client
99
99
  thin
100
- prometheus-client (2.0.0)
101
- pry (0.13.0)
100
+ prometheus-client (2.1.0)
101
+ pry (0.13.1)
102
102
  coderay (~> 1.1)
103
103
  method_source (~> 1.0)
104
104
  pry-byebug (3.9.0)
105
105
  byebug (~> 11.0)
106
106
  pry (~> 0.13.0)
107
- public_suffix (4.0.4)
108
- rack (2.2.2)
107
+ public_suffix (4.0.5)
108
+ rack (2.2.3)
109
109
  rake (13.0.1)
110
110
  rspec (3.9.0)
111
111
  rspec-core (~> 3.9.0)
112
112
  rspec-expectations (~> 3.9.0)
113
113
  rspec-mocks (~> 3.9.0)
114
- rspec-core (3.9.1)
115
- rspec-support (~> 3.9.1)
116
- rspec-expectations (3.9.1)
114
+ rspec-core (3.9.2)
115
+ rspec-support (~> 3.9.3)
116
+ rspec-expectations (3.9.2)
117
117
  diff-lcs (>= 1.2.0, < 2.0)
118
118
  rspec-support (~> 3.9.0)
119
119
  rspec-mocks (3.9.1)
120
120
  diff-lcs (>= 1.2.0, < 2.0)
121
121
  rspec-support (~> 3.9.0)
122
- rspec-support (3.9.2)
122
+ rspec-support (3.9.3)
123
123
  safe_yaml (1.0.5)
124
- thin (1.7.2)
124
+ thin (1.8.0)
125
125
  daemons (~> 1.0, >= 1.0.9)
126
126
  eventmachine (~> 1.0, >= 1.0.4)
127
127
  rack (>= 1, < 3)
128
128
  thread_safe (0.3.6)
129
- tzinfo (1.2.7)
129
+ tzinfo (1.2.9)
130
130
  thread_safe (~> 0.1)
131
131
  webmock (3.8.3)
132
132
  addressable (>= 2.3.6)
133
133
  crack (>= 0.3.2)
134
134
  hashdiff (>= 0.4.0, < 2.0.0)
135
- websocket-driver (0.7.1)
135
+ websocket-driver (0.7.3)
136
136
  websocket-extensions (>= 0.1.0)
137
- websocket-extensions (0.1.4)
137
+ websocket-extensions (0.1.5)
138
138
 
139
139
  PLATFORMS
140
140
  ruby
@@ -1,5 +1,5 @@
1
1
  module Peatio
2
2
  module Bitgo
3
- VERSION = "2.6.1".freeze
3
+ VERSION = "2.6.6".freeze
4
4
  end
5
5
  end
@@ -2,9 +2,13 @@ module Peatio
2
2
  module Bitgo
3
3
  class Wallet < Peatio::Wallet::Abstract
4
4
  TIME_DIFFERENCE_IN_MINUTES = 10
5
+ XLM_MEMO_TYPES = { 'memoId': 'id', 'memoText': 'text', 'memoHash': 'hash', 'memoReturn': 'return' }
5
6
 
6
- def initialize(settings = {})
7
- @settings = settings
7
+ DEFAULT_FEATURES = { skip_deposit_collection: false }.freeze
8
+
9
+ def initialize(custom_features = {})
10
+ @features = DEFAULT_FEATURES.merge(custom_features).slice(*SUPPORTED_FEATURES)
11
+ @settings = {}
8
12
  end
9
13
 
10
14
  def configure(settings = {})
@@ -57,7 +61,7 @@ module Peatio
57
61
  end
58
62
 
59
63
  txid = client.rest_api(:post, "#{currency_id}/wallet/#{wallet_id}/sendcoins", {
60
- address: transaction.to_address.to_s,
64
+ address: normalize_address(transaction.to_address.to_s),
61
65
  amount: amount.to_s,
62
66
  walletPassphrase: bitgo_wallet_passphrase,
63
67
  memo: xlm_memo(transaction.to_address.to_s)
@@ -115,16 +119,21 @@ module Peatio
115
119
  raise Peatio::Wallet::ClientError, e
116
120
  end
117
121
 
118
- def trigger_webhook_event(event)
122
+ def trigger_webhook_event(request)
119
123
  currency = @wallet.fetch(:testnet).present? ? 't' + @currency.fetch(:id) : @currency.fetch(:id)
120
- return unless currency == event['coin'] && @wallet.fetch(:wallet_id) == event['wallet']
121
-
122
- if event['type'] == 'transfer'
123
- transactions = fetch_transfer!(event['transfer'])
124
- return { transfers: transactions }
125
- elsif event['type'] == 'address_confirmation'
126
- address_id = fetch_address_id(event['address'])
127
- return { address_id: address_id, currency_id: currency_id }
124
+ if request.params['type'] == 'transfer'
125
+ return unless currency == request.params['coin'] &&
126
+ @wallet.fetch(:wallet_id) == request.params['wallet']
127
+ else
128
+ return unless @wallet.fetch(:wallet_id) == request.params['walletId']
129
+ end
130
+
131
+ if request.params['type'] == 'transfer'
132
+ transactions = fetch_transfer!(request.params['transfer'])
133
+ return transactions
134
+ elsif request.params['type'] == 'address_confirmation'
135
+ address_id = fetch_address_id(request.params['address'])
136
+ return { address_id: address_id, address: request.params['address'], currency_id: currency_id }
128
137
  end
129
138
  end
130
139
 
@@ -142,7 +151,6 @@ module Peatio
142
151
  end
143
152
 
144
153
  def fetch_transfer!(id)
145
- # TODO: Add Rspecs for this one
146
154
  response = client.rest_api(:get, "#{currency_id}/wallet/#{wallet_id}/transfer/#{id}")
147
155
  parse_entries(response['entries']).map do |entry|
148
156
  to_address = if response.dig('coinSpecific', 'memo').present?
@@ -154,14 +162,18 @@ module Peatio
154
162
  end
155
163
  state = define_transaction_state(response['state'])
156
164
 
165
+ if response['outputs'].present?
166
+ output = response['outputs'].find { |out| out['address'] == to_address }
167
+ txout = output['index'] if output.present?
168
+ end
169
+
157
170
  transaction = Peatio::Transaction.new(
158
171
  currency_id: @currency.fetch(:id),
159
172
  amount: convert_from_base_unit(entry['valueString']),
160
173
  hash: normalize_txid(response['txid']),
161
174
  to_address: to_address,
162
175
  block_number: response['height'],
163
- # TODO: Add sendmany support
164
- txout: 0,
176
+ txout: txout.to_i,
165
177
  status: state
166
178
  )
167
179
 
@@ -221,19 +233,25 @@ module Peatio
221
233
  end
222
234
 
223
235
  def xlm_memo(address)
224
- if @currency.fetch(:id) == 'xlm'
225
- {
226
- type: "id",
227
- value: "#{memo_id_from(address)}"
228
- }
229
- end
236
+ build_xlm_memo(address) if @currency.fetch(:id) == 'xlm'
230
237
  end
231
238
 
232
- def memo_id_from(address)
233
- memo_id = address.partition('memoId=').last
234
- memo_id = 0 if memo_id.empty?
239
+ def build_xlm_memo(address)
240
+ case address.split('?').last.split('=').first
241
+ when 'memoId'
242
+ memo_value_from(address, 'memoId')
243
+ when 'memoText'
244
+ memo_value_from(address, 'memoText')
245
+ when 'memoHash'
246
+ memo_value_from(address, 'memoHash')
247
+ when 'memoReturn'
248
+ memo_value_from(address, 'memoReturn')
249
+ end
250
+ end
235
251
 
236
- memo_id
252
+ def memo_value_from(address, type)
253
+ memo_value = address.partition(type + '=').last
254
+ return { type: XLM_MEMO_TYPES[type.to_sym], value: memo_value } if memo_value.present?
237
255
  end
238
256
 
239
257
  def currency_id
@@ -248,6 +266,14 @@ module Peatio
248
266
  @wallet.fetch(:wallet_id)
249
267
  end
250
268
 
269
+ def normalize_address(address)
270
+ if @currency.fetch(:id) == 'xlm'
271
+ address.split('?').first
272
+ else
273
+ address
274
+ end
275
+ end
276
+
251
277
  def normalize_txid(txid)
252
278
  txid.downcase
253
279
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: peatio-bitgo
3
3
  version: !ruby/object:Gem::Version
4
- version: 2.6.1
4
+ version: 2.6.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - Nadia Ch., Maksym N.
8
8
  autorequire:
9
9
  bindir: exe
10
10
  cert_chain: []
11
- date: 2020-06-10 00:00:00.000000000 Z
11
+ date: 2021-04-15 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: activesupport
@@ -239,7 +239,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
239
239
  - !ruby/object:Gem::Version
240
240
  version: '0'
241
241
  requirements: []
242
- rubygems_version: 3.0.3
242
+ rubygems_version: 3.0.3.1
243
243
  signing_key:
244
244
  specification_version: 4
245
245
  summary: Gem for extending Peatio plugable system with Bitgo implementation.