cns 0.8.7 → 0.8.9

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: b3630eeaca7e56e765e2702bc46c885b19c9e5127239f6788ce510358d3b2d7e
4
- data.tar.gz: b2b87a278f6042d604d964f1c2bdd8d20db4b7a7d8d3c9448f36afbc2e2d8a08
3
+ metadata.gz: aa9737420761247a9d82111220ba71741c591fa08fe035da2f8f4717cd8b179d
4
+ data.tar.gz: 6e5b7f03930de50c278a0a1d0a6442b6535c67bfa1874f0402b2c4075c363108
5
5
  SHA512:
6
- metadata.gz: ec9c373225a2870fa14bc4eeefde9c20f6a2152a173108ce14e0f6b4bf948c7784b85337c3b0dc2f94ebaae005313c9145849805eff161f6bff094538ba942eb
7
- data.tar.gz: ebd9ed2c6d303bd6e6ba9fd533b9d9198dd8751ebe2f86c81e4b8dfcae4e5b8e632310e45a322b9dd1ed7f78a1bda4efb0a4127fc953710b133f2248b009722c
6
+ metadata.gz: 92144b9670390bf051d131f2bdf1b35a8c475ac16fa935dc2f6bb37b04298a5304ceadceeac467da687d70e847ee5cfc3974d6deca8519b8a368c3bec446334d
7
+ data.tar.gz: 1f519cc3912a0ea47d1cabb557eb191c04dafd6dc308d08da23969ae2fc604f720f3441844c277b1259f446a20aad28645ccf4868d6c5e795efeef17e7f5ef97
data/Gemfile.lock CHANGED
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- cns (0.8.7)
4
+ cns (0.8.9)
5
5
  curb
6
6
  faraday
7
7
  google-cloud-bigquery
data/lib/cns/bigquery.rb CHANGED
@@ -7,6 +7,7 @@ require('bigdecimal/util')
7
7
  module Cns
8
8
  BD = 'hernanirvaz.coins'
9
9
  FO = File.expand_path("~/#{File.basename($PROGRAM_NAME)}.log")
10
+ EM = %i[EOS XETH ZEUR btc eth]
10
11
  TB = {
11
12
  i: %w[blocknumber timestamp txhash axfrom axto iax value contractaddress input type gas gasused traceid iserror errcode dias],
12
13
  p: %w[blocknumber timestamp blockreward iax dias],
@@ -44,8 +45,8 @@ module Cns
44
45
  def mtudo
45
46
  apius.mresumo
46
47
  apide.mresumo
47
- apies.mresumo
48
- apigm.mresumo
48
+ # apies.mresumo
49
+ # apigm.mresumo
49
50
  end
50
51
 
51
52
  # mostra situacao completa entre kraken/etherscan & bigquery
@@ -209,6 +210,7 @@ module Cns
209
210
  novx = src.send("nov#{prx}#{itm}")
210
211
  next if novx.empty?
211
212
 
213
+ # puts(insert_cus(prx, itm, novx))
212
214
  str << format(' %<n>i %<t>s', n: dml(insert_cus(prx, itm, novx)), t: "#{prx}#{itm}")
213
215
  end
214
216
  str.join
@@ -219,6 +221,7 @@ module Cns
219
221
  novx = src.send("nov#{prx}#{itm}")
220
222
  next if novx.empty?
221
223
 
224
+ # puts(insert_out(prx, itm, novx))
222
225
  str << format(' %<n>i %<t>s', n: dml(insert_out(prx, itm, novx)), t: "#{prx}#{itm}")
223
226
  end
224
227
  str.join
@@ -256,7 +259,7 @@ module Cns
256
259
  end
257
260
 
258
261
  def fts(value)
259
- "DATETIME(TIMESTAMP('#{value}'))"
262
+ "DATETIME(TIMESTAMP('#{value.iso8601}'))"
260
263
  end
261
264
 
262
265
  # @param [Hash] htx transacao norml etherscan
@@ -303,7 +306,7 @@ module Cns
303
306
  fnm(htx[:gasUsed]),
304
307
  fqt(htx[:traceId]),
305
308
  fin(htx[:isError]),
306
- fin(htx[:errCode]),
309
+ fqt(htx[:errCode]),
307
310
  fin(ops.dig(:h, htx[:hash]))
308
311
  ]
309
312
  "(#{vls.join(',')})"
@@ -325,7 +328,7 @@ module Cns
325
328
  fqt(htx[:address]),
326
329
  fnm(htx[:amount]),
327
330
  fin(htx[:blockNumber]),
328
- fin(htx[:timestamp]),
331
+ fin(htx[:timeStamp]),
329
332
  fin(ops.dig(:h, htx[:withdrawalIndex]))
330
333
  ]
331
334
  "(#{vls.join(',')})"
@@ -362,23 +365,23 @@ module Cns
362
365
  # @param [Hash] hlx ledger greymass
363
366
  # @return [String] valores formatados para insert eos (parte1)
364
367
  def neost_val(htx)
365
- act = htx[:action_trace][:act]
366
- dat = act[:data]
367
- qtd = dat[:quantity].to_s
368
- str = dat[:memo].inspect
368
+ # act = htx[:action_trace][:act]
369
+ # dat = act[:data]
370
+ # qtd = dat[:quantity].to_s
371
+ # str = dat[:memo].inspect
369
372
  vls = [
370
373
  fin(htx[:global_action_seq]),
371
374
  fin(htx[:account_action_seq]),
372
375
  fin(htx[:block_num]),
373
376
  fts(htx[:block_time]),
374
- fqt(act[:account]),
375
- fqt(act[:name]),
376
- fqt(dat[:from]),
377
- fqt(dat[:to]),
377
+ fqt(htx[:account]),
378
+ fqt(htx[:name]),
379
+ fqt(htx[:from]),
380
+ fqt(htx[:to]),
378
381
  fqt(htx[:iax]),
379
- fnm(qtd),
380
- fqt(qtd[/[[:upper:]]+/]),
381
- fqt(str),
382
+ fnm(htx[:quantity]),
383
+ fqt(htx[:moe]),
384
+ fqt(htx[:memo]),
382
385
  fin(ops.dig(:h, htx[:itx]))
383
386
  ]
384
387
  "(#{vls.join(',')})"
@@ -403,15 +406,13 @@ module Cns
403
406
  # @param [Hash] hlx ledger (deposits + withdrawals) bitcoinde
404
407
  # @return [String] valores formatados del (ledger)
405
408
  def cdel_val(htx)
406
- tip = htx[:tp]
407
- qtd = htx[:qt]
408
409
  vls = [
409
410
  fin(htx[:txid]),
410
- fts(htx[:time].iso8601),
411
- fqt(tip),
411
+ fts(htx[:time]),
412
+ fqt(htx[:tp]),
412
413
  fqt(htx[:add]),
413
414
  fqt(htx[:moe]),
414
- fnm(tip == 'withdrawal' ? "-#{qtd}" : "#{qtd}"),
415
+ fnm(htx[:tp] == 'withdrawal' ? "-#{htx[:qt]}" : "#{htx[:qt]}"),
415
416
  fnm(htx[:fee])
416
417
  ]
417
418
  "(#{vls.join(',')})"
@@ -421,12 +422,13 @@ module Cns
421
422
  # @param [Hash] htx trade kraken
422
423
  # @return [String] valores formatados ust (trades parte1)
423
424
  def cust_val(idx, htx)
425
+ # gets ledgers related to this trade
424
426
  ldg = apius.exd[:kl].select { |_, obj| obj[:refid] == idx.to_s }.keys.join(',')
425
427
  vls = [
426
428
  fqt(idx),
427
429
  fqt(htx[:ordertxid]),
428
430
  fqt(htx[:pair]),
429
- ftm(htx[:time]),
431
+ fts(htx[:time]),
430
432
  fqt(htx[:type]),
431
433
  fqt(htx[:ordertype]),
432
434
  fnm(htx[:price]),
@@ -445,7 +447,7 @@ module Cns
445
447
  # @param [Hash] hlx ledger kraken
446
448
  # @return [String] valores formatados usl (ledger)
447
449
  def cusl_val(idx, hlx)
448
- vls = [fqt(idx), fqt(hlx[:refid]), ftm(hlx[:time]), fqt(hlx[:type]), fqt(hlx[:aclass]), fqt(hlx[:asset]), fnm(hlx[:amount]), fnm(hlx[:fee])]
450
+ vls = [fqt(idx), fqt(hlx[:refid]), fts(hlx[:time]), fqt(hlx[:type]), fqt(hlx[:aclass]), fqt(hlx[:asset]), fnm(hlx[:amount]), fnm(hlx[:fee])]
449
451
  "(#{vls.join(',')})"
450
452
  end
451
453
  end
data/lib/cns/bitcoinde.rb CHANGED
@@ -25,6 +25,11 @@ module Cns
25
25
  @ops = pop.transform_keys(&:to_sym)
26
26
  end
27
27
 
28
+ # @return [Hash] dados exchange bitcoinde - saldos & trades & deposits & withdrawals
29
+ def exd
30
+ @exd ||= { sl: pdea(api.account_de), tt: pdet(api.trades_de), tl: pdel(api.deposits_de + api.withdrawals_de) }
31
+ end
32
+
28
33
  # @return [Array<Hash>] lista trades bitcoinde novos
29
34
  def novcdet
30
35
  @novcdet ||= exd[:tt].select { |obj| kyt.include?(obj[:trade_id]) }
@@ -38,7 +43,7 @@ module Cns
38
43
  # @return [String] texto saldos & transacoes & ajuste dias
39
44
  def mresumo
40
45
  puts("\nBITCOINDE\ntipo bitcoinde bigquery")
41
- exd[:sl].sort { |ant, prx| ant <=> prx }.each { |key, val| puts(formata_saldos(key, val)) }
46
+ exd[:sl].sort.each { |key, val| puts(formata_saldos(key, val)) }
42
47
  mtotais
43
48
 
44
49
  mtrades
@@ -48,27 +53,36 @@ module Cns
48
53
  puts("\nstring ajuste dias dos trades\n-h=#{kyt.map { |obj| "#{obj}:0" }.join(' ')}")
49
54
  end
50
55
 
51
- # @return [Hash] dados exchange bitcoinde - saldos & trades & deposits & withdrawals
52
- def exd
53
- @exd ||= { sl: api.account_de, tt: api.trades_de, tl: api.deposits_de + api.withdrawals_de }
56
+ private
57
+
58
+ def show_all?
59
+ ops[:t] || false
60
+ end
61
+
62
+ def bqkyt
63
+ show_all? ? [] : (bqd[:nt]&.map { |t| t[:txid] } || [])
64
+ end
65
+
66
+ def bqkyl
67
+ show_all? ? [] : (bqd[:nl]&.map { |l| l[:txid] } || [])
54
68
  end
55
69
 
56
70
  # @return [Array<String>] lista txid dos trades novos
57
71
  def kyt
58
- @kyt ||= exd[:tt].map { |oex| oex[:trade_id] }.flatten - (ops[:t] ? [] : bqd[:nt].map { |obq| obq[:txid] })
72
+ @kyt ||= exd[:tt].map { |oex| oex[:trade_id] } - bqkyt
59
73
  end
60
74
 
61
75
  # @return [Array<Integer>] lista txid dos ledger novos
62
76
  def kyl
63
- @kyl ||= exd[:tl].map { |oex| oex[:txid] }.flatten - (ops[:t] ? [] : bqd[:nl].map { |obq| obq[:txid] })
77
+ @kyl ||= exd[:tl].map { |oex| oex[:txid] } - bqkyl
64
78
  end
65
79
 
66
80
  # @param [String] moe codigo bitcoinde da moeda
67
81
  # @param [Hash] hsx saldo bitcoinde da moeda
68
82
  # @return [String] texto formatado saldos
69
83
  def formata_saldos(moe, hsx)
70
- vbq = bqd[:sl][moe.downcase.to_sym].to_d.round(9)
71
- vex = hsx[:total_amount].to_d.round(9)
84
+ vbq = bqd[:sl][moe.downcase.to_sym].to_d
85
+ vex = hsx[:total_amount]
72
86
  format(
73
87
  '%<mo>-5.5s %<ex>21.9f %<bq>21.9f %<ok>3.3s',
74
88
  mo: moe.upcase,
@@ -84,12 +98,12 @@ module Cns
84
98
  format(
85
99
  '%<ky>-6.6s %<dt>19.19s %<dp>10.10s %<ty>-5.5s %<mo>-8.8s %<vl>18.8f %<co>8.2f',
86
100
  ky: htx[:trade_id],
87
- dt: Time.parse(htx[:successfully_finished_at]),
88
- dp: Time.parse(htx[:trade_marked_as_paid_at]),
101
+ dt: htx[:successfully_finished_at].strftime('%F %T'),
102
+ dp: htx[:trade_marked_as_paid_at].strftime('%F'),
89
103
  ty: htx[:type],
90
- mo: htx[:trading_pair].upcase,
91
- vl: htx[:amount_currency_to_trade].to_d,
92
- co: htx[:volume_currency_to_pay].to_d
104
+ mo: htx[:trading_pair],
105
+ vl: htx[:amount_currency_to_trade],
106
+ co: htx[:volume_currency_to_pay]
93
107
  )
94
108
  end
95
109
 
@@ -99,11 +113,11 @@ module Cns
99
113
  format(
100
114
  '%<ky>6i %<dt>19.19s %<ty>-10.10s %<mo>-3.3s %<pr>19.8f %<vl>18.8f',
101
115
  ky: hlx[:txid],
102
- dt: hlx[:time],
116
+ dt: hlx[:time].strftime('%F %T'),
103
117
  ty: hlx[:tp],
104
- mo: hlx[:moe].upcase,
105
- pr: hlx[:qt].to_d,
106
- vl: hlx[:fee].to_d
118
+ mo: hlx[:moe],
119
+ pr: hlx[:qt],
120
+ vl: hlx[:fee]
107
121
  )
108
122
  end
109
123
 
@@ -123,7 +137,7 @@ module Cns
123
137
  return unless ops[:v] && !novcdet.empty?
124
138
 
125
139
  puts("\ntrades data hora dt criacao tipo par qtd eur")
126
- novcdet.sort { |ant, prx| Time.parse(prx[:successfully_finished_at]) <=> Time.parse(ant[:successfully_finished_at]) }.each { |obj| puts(formata_trades(obj)) }
140
+ novcdet.sort_by { |itm| -itm[:srx] }.each { |obj| puts(formata_trades(obj)) }
127
141
  end
128
142
 
129
143
  # @return [String] texto transacoes ledger
@@ -131,7 +145,36 @@ module Cns
131
145
  return unless ops[:v] && !novcdel.empty?
132
146
 
133
147
  puts("\nledger data hora tipo moe quantidade custo")
134
- novcdel.sort { |ant, prx| prx[:time] <=> ant[:time] }.each { |obj| puts(formata_ledger(obj)) }
148
+ novcdel.sort_by { |itm| -itm[:srx] }.each { |obj| puts(formata_ledger(obj)) }
149
+ end
150
+
151
+ # Processa os trades para garantir que as datas estejam no formato correto
152
+ def pdea(itm)
153
+ itm.select { |ky1, _| EM.include?(ky1) }.transform_values { |o| o.merge(total_amount: o[:total_amount].to_d) }
154
+ end
155
+
156
+ # Processa os trades para garantir que as datas estejam no formato correto
157
+ def pdet(itm)
158
+ itm.map do |t|
159
+ t.merge(
160
+ successfully_finished_at: srx = ptm(t[:successfully_finished_at]),
161
+ srx: Integer(srx),
162
+ trade_marked_as_paid_at: ptm(t[:trade_marked_as_paid_at]),
163
+ amount_currency_to_trade: t[:amount_currency_to_trade].to_d,
164
+ volume_currency_to_pay: t[:volume_currency_to_pay].to_d,
165
+ trading_pair: t[:trading_pair].upcase
166
+ )
167
+ end
168
+ end
169
+
170
+ # Processa os ledger entries para garantir que as datas estejam no formato correto
171
+ def pdel(itm)
172
+ itm.map { |t| t.merge(time: srx = ptm(t[:time]), srx: Integer(srx), qt: t[:qt].to_d, fee: t[:fee].to_d, moe: t[:moe].upcase) }
173
+ end
174
+
175
+ # Processa time field somtimes is string
176
+ def ptm(itm)
177
+ itm.is_a?(String) ? Time.parse(itm) : itm
135
178
  end
136
179
  end
137
180
  end
data/lib/cns/etherscan.rb CHANGED
@@ -69,32 +69,27 @@ module Cns
69
69
 
70
70
  # @return [Array<Integer>] lista indices transacoes normais novas
71
71
  def idt
72
- @idt ||= bcd.map { |obc| obc[:tx].map { |obj| obj[:itx] } }.flatten -
73
- (ops[:t] ? [] : bqd[:nt].map { |obq| obq[:itx] })
72
+ @idt ||= bcd.map { |obc| obc[:tx].map { |obj| obj[:itx] } }.flatten - (ops[:t] ? [] : bqd[:nt].map { |obq| obq[:itx] })
74
73
  end
75
74
 
76
75
  # @return [Array<Integer>] lista indices transacoes internas novas
77
76
  def idi
78
- @idi ||= bcd.map { |obc| obc[:ix].map { |obj| obj[:itx] } }.flatten -
79
- (ops[:t] ? [] : bqd[:ni].map { |obq| obq[:itx] })
77
+ @idi ||= bcd.map { |obc| obc[:ix].map { |obj| obj[:itx] } }.flatten - (ops[:t] ? [] : bqd[:ni].map { |obq| obq[:itx] })
80
78
  end
81
79
 
82
80
  # @return [Array<Integer>] lista indices transacoes block novas
83
81
  def idp
84
- @idp ||= bcd.map { |obc| obc[:px].map { |obj| obj[:itx] } }.flatten -
85
- (ops[:t] ? [] : bqd[:np].map { |obq| obq[:itx] })
82
+ @idp ||= bcd.map { |obc| obc[:px].map { |obj| obj[:itx] } }.flatten - (ops[:t] ? [] : bqd[:np].map { |obq| obq[:itx] })
86
83
  end
87
84
 
88
85
  # @return [Array<Integer>] lista indices transacoes withdrawals novas
89
86
  def idw
90
- @idw ||= bcd.map { |obc| obc[:wx].map { |obj| obj[:itx] } }.flatten -
91
- (ops[:t] ? [] : bqd[:nw].map { |obq| obq[:itx] })
87
+ @idw ||= bcd.map { |obc| obc[:wx].map { |obj| obj[:itx] } }.flatten - (ops[:t] ? [] : bqd[:nw].map { |obq| obq[:itx] })
92
88
  end
93
89
 
94
90
  # @return [Array<Integer>] lista indices transacoes token novas
95
91
  def idk
96
- @idk ||= bcd.map { |obc| obc[:kx].map { |obj| obj[:itx] } }.flatten -
97
- (ops[:t] ? [] : bqd[:nk].map { |obq| obq[:itx] })
92
+ @idk ||= bcd.map { |obc| obc[:kx].map { |obj| obj[:itx] } }.flatten - (ops[:t] ? [] : bqd[:nk].map { |obq| obq[:itx] })
98
93
  end
99
94
 
100
95
  # @example (see Apibc#account_es)
@@ -104,12 +99,12 @@ module Cns
104
99
  acc = abc[:account].downcase
105
100
  {
106
101
  ax: acc,
107
- sl: (abc[:balance].to_d / (10**18)),
108
- tx: filtrar_tx(acc, api.norml_es(acc)),
109
- ix: filtrar_tx(acc, api.inter_es(acc)),
110
- px: filtrar_px(acc, api.block_es(acc)),
111
- wx: filtrar_wx(acc, api.withw_es(acc)),
112
- kx: filtrar_tx(acc, api.token_es(acc))
102
+ sl: abc[:balance].to_d / (10**18),
103
+ tx: ftik(acc, api.norml_es(acc)),
104
+ ix: ftik(acc, api.inter_es(acc)),
105
+ px: fppp(acc, api.block_es(acc)),
106
+ wx: fwww(acc, api.withw_es(acc)),
107
+ kx: ftik(acc, api.token_es(acc))
113
108
  }
114
109
  end
115
110
 
@@ -135,56 +130,29 @@ module Cns
135
130
  }
136
131
  end
137
132
 
138
- # @param add (see Apibc#norml_es)
139
- # @param [Array<Hash>] ary lista transacoes/token events
140
- # @return [Array<Hash>] lista transacoes/token events filtrada
141
- def filtrar_tx(add, ary)
142
- # elimina transferencia from: (lax) to: (add) - esta transferencia aparece em from: (add) to: (lax)
143
- # .delete_if { |odl| add.casecmp?(odl[:to]) && lax.include?(odl[:from].downcase) }
144
- # elimina chaves irrelevantes (DL) & adiciona chave indice itx & adiciona identificador da carteira iax
145
- ary.map { |omp| omp.delete_if { |key, _| DL.include?(key) }.merge(itx: String(omp[:hash]), iax: add, srx: Integer(omp[:timeStamp])) }
146
- end
147
-
148
- # @param add (see Apibc#norml_es)
149
- # @param [Array<Hash>] ary lista blocks events
150
- # @return [Array<Hash>] lista blocks events filtrada
151
- def filtrar_px(add, ary)
152
- # adiciona chave indice itx & adiciona identificador da carteira iax
153
- ary.map { |omp| omp.merge(itx: Integer(omp[:blockNumber]), iax: add) }
154
- end
155
-
156
- # @param add (see Apibc#norml_es)
157
- # @param [Array<Hash>] ary lista blocks events
158
- # @return [Array<Hash>] lista blocks events filtrada
159
- def filtrar_wx(add, ary)
160
- # adiciona chave indice itx & adiciona identificador da carteira iax
161
- ary.map { |omp| omp.merge(itx: Integer(omp[:withdrawalIndex]), iax: add) }
162
- end
163
-
164
- # dt: Time.at(Integer(htx[:timeStamp])),
165
133
  # @return [Array<Hash>] lista ordenada transacoes normais novas
166
134
  def sortx
167
- novnetht.sort { |ant, prx| ant[:srx] <=> prx[:srx] }
135
+ novnetht.sort_by { |itm| -itm[:srx] }
168
136
  end
169
137
 
170
138
  # @return [Array<Hash>] lista ordenada transacoes internas novas
171
139
  def sorix
172
- novnethi.sort { |ant, prx| ant[:srx] <=> prx[:srx] }
140
+ novnethi.sort_by { |itm| -itm[:srx] }
173
141
  end
174
142
 
175
143
  # @return [Array<Hash>] lista ordenada transacoes block novas
176
144
  def sorpx
177
- novnethp.sort { |ant, prx| ant[:itx] <=> prx[:itx] }
145
+ novnethp.sort_by { |itm| -itm[:itx] }
178
146
  end
179
147
 
180
148
  # @return [Array<Hash>] lista ordenada transacoes withdrawals novas
181
149
  def sorwx
182
- novnethw.sort { |ant, prx| ant[:itx] <=> prx[:itx] }
150
+ novnethw.sort_by { |itm| -itm[:itx] }
183
151
  end
184
152
 
185
153
  # @return [Array<Hash>] lista ordenada transacoes token novas
186
154
  def sorkx
187
- novnethk.sort { |ant, prx| ant[:srx] <=> prx[:srx] }
155
+ novnethk.sort_by { |itm| -itm[:srx] }
188
156
  end
189
157
 
190
158
  # @return [String] texto carteiras & transacoes & ajuste dias
@@ -230,23 +198,12 @@ module Cns
230
198
  # @param (see formata_carteira)
231
199
  # @return [String] texto formatado valores duma carteira
232
200
  def formata_valores_simples(hjn)
233
- # id address etherscan bigquery
234
- # me-app 0x27c7f54e48956a906af2cbfbc8684b437776403d 22.377364 22.377364 OK
235
- # mm-hot 0x534029b6371dc4453dd750bc1198181f55c859fe 4.556609 4.556609 OK
236
- format(
237
- '%<v1>13.6f %<v2>13.6f %<ok>-3s',
238
- v1: hjn[:es],
239
- v2: hjn[:bs],
240
- ok: ok?(hjn) ? 'OK' : 'NOK'
241
- )
201
+ format('%<v1>13.6f %<v2>13.6f %<ok>-3s', v1: hjn[:es], v2: hjn[:bs], ok: ok?(hjn) ? 'OK' : 'NOK')
242
202
  end
243
203
 
244
204
  # @param (see formata_carteira)
245
205
  # @return [String] texto formatado valores duma carteira
246
206
  def formata_valores(hjn)
247
- # id address etherscan tn ti tb tk tw bigquery tn ti tb tk tw
248
- # me-app 0x27c..b43 22.3774 31 6 0 16 2190 22.3774 25 6 0 16 2190 OK
249
- # mm-hot 0x534..81f 4.5566 182 18 74 7 51 4.5566 33 18 74 6 51 OK
250
207
  format(
251
208
  '%<v1>11.4f %<n1>3i %<n2>2i %<n3>2i %<n4>2i %<w1>4i %<v2>11.4f %<n5>3i %<n6>2i %<n7>2i %<n8>2i %<w2>4i %<ok>-3s',
252
209
  v1: hjn[:es],
@@ -272,7 +229,6 @@ module Cns
272
229
 
273
230
  # @example ether address inicio..fim
274
231
  # 0x10f3a0cf0b534c..c033cf32e8a03586
275
- # @param add (see filtrar_tx)
276
232
  # @param [Integer] max chars a mostrar
277
233
  # @return [String] endereco formatado
278
234
  def formata_enderec1(add, max)
@@ -286,7 +242,6 @@ module Cns
286
242
 
287
243
  # @example ether address inicio..fim
288
244
  # me-app..4b437776403d
289
- # @param add (see filtrar_tx)
290
245
  # @param [Integer] max chars a mostrar
291
246
  # @return [String] endereco formatado
292
247
  def formata_enderec2(add, max)
@@ -309,8 +264,8 @@ module Cns
309
264
  hx: formata_enderec1(htx[:hash], 29),
310
265
  fr: formata_enderec2(htx[:from], 15),
311
266
  to: formata_enderec2(htx[:to], 15),
312
- dt: Time.at(Integer(htx[:timeStamp])),
313
- vl: (htx[:value].to_d / (10**18)).round(10)
267
+ dt: htx[:timeStamp].strftime('%F'),
268
+ vl: htx[:value] / (10**18)
314
269
  )
315
270
  end
316
271
 
@@ -323,8 +278,8 @@ module Cns
323
278
  hx: formata_enderec1(hkx[:hash], 23),
324
279
  fr: formata_enderec2(hkx[:from], 15),
325
280
  to: formata_enderec2(hkx[:to], 15),
326
- dt: Time.at(Integer(hkx[:timeStamp])),
327
- vl: (hkx[:value].to_d / (10**18)).round(10),
281
+ dt: hkx[:timeStamp].strftime('%F'),
282
+ vl: hkx[:value] / (10**18),
328
283
  sy: hkx[:tokenSymbol]
329
284
  )
330
285
  end
@@ -337,8 +292,8 @@ module Cns
337
292
  '%<bn>9i %<fr>-41.41s %<dt>10.10s %<vl>17.6f',
338
293
  bn: htx[:blockNumber],
339
294
  fr: formata_enderec2(htx[:iax], 41),
340
- dt: Time.at(Integer(htx[:timeStamp])),
341
- vl: (htx[:blockReward].to_d / (10**18)).round(10)
295
+ dt: htx[:timeStamp].strftime('%F'),
296
+ vl: htx[:blockReward] / (10**18)
342
297
  )
343
298
  end
344
299
 
@@ -346,13 +301,7 @@ module Cns
346
301
  # @param [Hash] htx transacao withdrawals etherscan
347
302
  # @return [String] texto formatado transacao withdrawals etherscan
348
303
  def formata_tx_withw(htx)
349
- format(
350
- '%<bn>10i %<vi>9i %<dt>10.10s %<vl>10.6f',
351
- bn: htx[:withdrawalIndex],
352
- vi: htx[:validatorIndex],
353
- dt: Time.at(Integer(htx[:timestamp])),
354
- vl: (htx[:amount].to_d / (10**9)).round(10)
355
- )
304
+ format('%<bn>10i %<vi>9i %<dt>10.10s %<vl>10.6f', bn: htx[:withdrawalIndex], vi: htx[:validatorIndex], dt: htx[:timeStamp].strftime('%F'), vl: htx[:amount] / (10**9))
356
305
  end
357
306
 
358
307
  # @return [String] texto transacoes normais
@@ -400,8 +349,31 @@ module Cns
400
349
  puts("\najuste dias transacoes normais \n-h=#{sortx.map { |obj| "#{obj[:hash]}:0" }.join(' ')}") if novnetht.count.positive?
401
350
  puts("\najuste dias transacoes internas \n-h=#{sorix.map { |obj| "#{obj[:hash]}:0" }.join(' ')}") if novnethi.count.positive?
402
351
  puts("\najuste dias transacoes block \n-h=#{sorpx.map { |obj| "#{obj[:blockNumber]}:0" }.join(' ')}") if novnethp.count.positive?
403
- puts("\najuste dias transacoes withdrawals\n-h=#{sorwx.map { |obj| "#{obj[:withdrawalIndex]}:0" }.join(' ')}") if novnethw.count.positive?
404
352
  puts("\najuste dias transacoes token \n-h=#{sorkx.map { |obj| "#{obj[:hash]}:0" }.join(' ')}") if novnethk.count.positive?
353
+ puts("\najuste dias transacoes withdrawals\n-h=#{sorwx.map { |obj| "#{obj[:withdrawalIndex]}:0" }.join(' ')}") if novnethw.count.positive?
354
+ end
355
+
356
+ private
357
+
358
+ # @param add (see Apibc#norml_es)
359
+ # @param [Array<Hash>] ary lista transacoes/token events
360
+ # @return [Array<Hash>] lista transacoes/token events filtrada
361
+ def ftik(add, ary)
362
+ ary.map { |o| o.merge(itx: String(o[:hash]), iax: add, value: o[:value].to_d, srx: (tym = Integer(o[:timeStamp])), timeStamp: Time.at(tym)) }
363
+ end
364
+
365
+ # @param add (see Apibc#norml_es)
366
+ # @param [Array<Hash>] ary lista blocks events
367
+ # @return [Array<Hash>] lista blocks events filtrada
368
+ def fppp(add, ary)
369
+ ary.map { |o| o.merge(itx: Integer(o[:blockNumber]), iax: add, blockReward: o[:blockReward].to_d, timeStamp: Time.at(Integer(o[:timeStamp]))) }
370
+ end
371
+
372
+ # @param add (see Apibc#norml_es)
373
+ # @param [Array<Hash>] ary lista blocks events
374
+ # @return [Array<Hash>] lista blocks events filtrada
375
+ def fwww(add, ary)
376
+ ary.map { |o| o.merge(itx: Integer(o[:withdrawalIndex]), iax: add, amount: o[:amount].to_d, timeStamp: Time.at(Integer(o[:timestamp]))) }
405
377
  end
406
378
  end
407
379
  end
data/lib/cns/greymass.rb CHANGED
@@ -47,8 +47,7 @@ module Cns
47
47
 
48
48
  # @return [Array<Integer>] lista indices transacoes novas
49
49
  def idt
50
- @idt ||= bcd.map { |obc| obc[:tx].map { |obj| obj[:itx] } }.flatten -
51
- (ops[:t] ? [] : bqd[:nt].map { |obq| obq[:itx] })
50
+ @idt ||= bcd.map { |obc| obc[:tx].map { |obj| obj[:itx] } }.flatten - (ops[:t] ? [] : bqd[:nt].map { |obq| obq[:itx] })
52
51
  end
53
52
 
54
53
  # @example (see Apibc#account_gm)
@@ -56,11 +55,7 @@ module Cns
56
55
  # @return [Hash] dados greymass - address, saldo & transacoes
57
56
  def base_bc(wbq)
58
57
  xbq = wbq[:ax]
59
- {
60
- ax: xbq,
61
- sl: greymass_sl(xbq).reduce(:+),
62
- tx: filtrar_tx(xbq, api.ledger_gm(xbq))
63
- }
58
+ { ax: xbq, sl: peosa(xbq).reduce(:+), tx: peost(xbq, api.ledger_gm(xbq)) }
64
59
  end
65
60
 
66
61
  # @param wbq (see base_bc)
@@ -78,26 +73,6 @@ module Cns
78
73
  }
79
74
  end
80
75
 
81
- # @param (see filtrar_tx)
82
- # @return [Array<BigDecimal>] lista recursos - liquido, net, spu
83
- def greymass_sl(add)
84
- hac = api.account_gm(add)
85
- htr = hac[:total_resources]
86
- [hac[:core_liquid_balance].to_d, htr[:net_weight].to_d, htr[:cpu_weight].to_d]
87
- end
88
-
89
- # @param add (see Apibc#account_gm)
90
- # @param [Array<Hash>] ary lista transacoes
91
- # @return [Array<Hash>] lista transacoes filtrada
92
- def filtrar_tx(add, ary)
93
- # elimina transferencia from: (lax) to: (add) - esta transferencia aparece em from: (add) to: (lax)
94
- # adiciona chave indice itx & adiciona identificador da carteira iax
95
- (ary.delete_if do |odl|
96
- adt = odl[:action_trace][:act][:data]
97
- adt[:to] == add && lax.include?(adt[:from])
98
- end).map { |omp| omp.merge(itx: omp[:global_action_seq], iax: add) }
99
- end
100
-
101
76
  # @return [String] texto carteiras & transacoes & ajuste dias
102
77
  def mresumo
103
78
  return unless dados.count.positive?
@@ -134,13 +109,13 @@ module Cns
134
109
  def formata_ledger(hlx)
135
110
  format(
136
111
  '%<bn>12i %<fr>-12.12s %<to>-12.12s %<ac>-10.10s %<dt>10.10s %<vl>12.4f %<sy>-6.6s',
137
- ac: (act = hlx[:action_trace][:act])[:name],
138
- fr: (adt = act[:data])[:from],
139
- vl: (aqt = adt[:quantity].to_s).to_d,
112
+ ac: hlx[:name],
113
+ fr: hlx[:from],
114
+ vl: hlx[:quantity],
140
115
  bn: hlx[:itx],
141
- to: adt[:to],
142
- dt: Date.parse(hlx[:block_time]),
143
- sy: aqt[/[[:upper:]]+/]
116
+ to: hlx[:to],
117
+ dt: hlx[:block_time].strftime('%F'),
118
+ sy: hlx[:moe]
144
119
  )
145
120
  end
146
121
 
@@ -149,14 +124,48 @@ module Cns
149
124
  return unless ops[:v] && novneost.count.positive?
150
125
 
151
126
  puts("\nsequence num from to accao data valor moeda")
152
- novneost.sort { |ant, prx| prx[:itx] <=> ant[:itx] }.each { |obj| puts(formata_ledger(obj)) }
127
+ soreost.each { |obj| puts(formata_ledger(obj)) }
153
128
  end
154
129
 
155
130
  # @return [String] texto configuracao ajuste dias das transacoes
156
131
  def mconfiguracao_ajuste_dias
157
132
  return unless novneost.count.positive?
158
133
 
159
- puts("\nstring ajuste dias\n-h=#{novneost.sort { |ant, prx| prx[:itx] <=> ant[:itx] }.map { |obj| "#{obj[:itx]}:0" }.join(' ')}")
134
+ puts("\nstring ajuste dias\n-h=#{soreost.map { |obj| "#{obj[:itx]}:0" }.join(' ')}")
135
+ end
136
+
137
+ private
138
+
139
+ # @return [Array<Hash>] lista ordenada transacoes
140
+ def soreost
141
+ novneost.sort_by { |itm| -itm[:itx] }
142
+ end
143
+
144
+ # @return [Array<BigDecimal>] lista recursos - liquido, net, spu
145
+ def peosa(add)
146
+ hac = api.account_gm(add)
147
+ htr = hac[:total_resources]
148
+ [hac[:core_liquid_balance].to_d, htr[:net_weight].to_d, htr[:cpu_weight].to_d]
149
+ end
150
+
151
+ # @param add (see Apibc#account_gm)
152
+ # @param [Array<Hash>] ary lista transacoes
153
+ # @return [Array<Hash>] lista transacoes filtrada
154
+ def peost(add, ary)
155
+ ary.map do |omp|
156
+ omp.merge(
157
+ name: (act = omp[:action_trace][:act])[:name],
158
+ from: (adt = act[:data])[:from],
159
+ quantity: (qtd = adt[:quantity].to_s).to_d,
160
+ account: act[:account],
161
+ to: adt[:to],
162
+ memo: String(adt[:memo]).gsub(/\p{C}/, ''), # remove Non-Printable Characters
163
+ moe: qtd[/[[:upper:]]+/],
164
+ itx: omp[:global_action_seq],
165
+ iax: add,
166
+ block_time: Time.parse(omp[:block_time])
167
+ )
168
+ end
160
169
  end
161
170
  end
162
171
  end
data/lib/cns/kraken.rb CHANGED
@@ -25,6 +25,11 @@ module Cns
25
25
  @ops = pop.transform_keys(&:to_sym)
26
26
  end
27
27
 
28
+ # @return [Hash] dados exchange kraken - saldos & transacoes trades e ledger
29
+ def exd
30
+ @exd ||= { sl: pusa(api.account_us), kt: pust(api.trades_us), kl: pusl(api.ledger_us) }
31
+ end
32
+
28
33
  # @return [Hash] trades kraken novos
29
34
  def novcust
30
35
  @novcust ||= exd[:kt].slice(*kyt)
@@ -38,7 +43,7 @@ module Cns
38
43
  # @return [String] texto saldos & transacoes & ajuste dias
39
44
  def mresumo
40
45
  puts("\nKRAKEN\ntipo kraken bigquery")
41
- exd[:sl].sort { |ant, prx| ant <=> prx }.each { |key, val| puts(formata_saldos(key, val)) }
46
+ exd[:sl].sort.each { |key, val| puts(formata_saldos(key, val)) }
42
47
  mtotais
43
48
 
44
49
  mtrades
@@ -48,19 +53,28 @@ module Cns
48
53
  puts("\nstring ajuste dias dos trades\n-h=#{kyt.map { |obj| "#{obj}:0" }.join(' ')}")
49
54
  end
50
55
 
51
- # @return [Hash] dados exchange kraken - saldos & transacoes trades e ledger
52
- def exd
53
- @exd ||= { sl: api.account_us, kt: api.trades_us, kl: api.ledger_us }
56
+ private
57
+
58
+ def show_all?
59
+ ops[:t] || false
60
+ end
61
+
62
+ def bqkyt
63
+ show_all? ? [] : (bqd[:nt]&.map { |t| t[:txid].to_sym } || [])
64
+ end
65
+
66
+ def bqkyl
67
+ show_all? ? [] : (bqd[:nl]&.map { |l| l[:txid].to_sym } || [])
54
68
  end
55
69
 
56
70
  # @return [Array<String>] lista txid dos trades novos
57
71
  def kyt
58
- @kyt ||= exd[:kt].keys - (ops[:t] ? [] : bqd[:nt].map { |obj| obj[:txid].to_sym })
72
+ @kyt ||= exd[:kt].keys - bqkyt
59
73
  end
60
74
 
61
75
  # @return [Array<String>] lista txid dos ledger novos
62
76
  def kyl
63
- @kyl ||= exd[:kl].keys - (ops[:t] ? [] : bqd[:nl].map { |obj| obj[:txid].to_sym })
77
+ @kyl ||= exd[:kl].keys - bqkyl
64
78
  end
65
79
 
66
80
  # @example (see Apice#account_us)
@@ -68,14 +82,13 @@ module Cns
68
82
  # @param [BigDecimal] sal saldo kraken da moeda
69
83
  # @return [String] texto formatado saldos
70
84
  def formata_saldos(moe, sal)
71
- vbq = bqd[:sl][moe.downcase.to_sym].to_d.round(9)
72
- vsl = sal.to_d.round(9)
85
+ vbq = bqd[:sl][moe.downcase.to_sym].to_d
73
86
  format(
74
87
  '%<mo>-5.5s %<kr>21.9f %<bq>21.9f %<ok>3.3s',
75
88
  mo: moe.upcase,
76
- kr: vsl,
89
+ kr: sal,
77
90
  bq: vbq,
78
- ok: vbq == vsl ? 'OK' : 'NOK'
91
+ ok: vbq == sal ? 'OK' : 'NOK'
79
92
  )
80
93
  end
81
94
 
@@ -86,12 +99,12 @@ module Cns
86
99
  format(
87
100
  '%<ky>-6.6s %<dt>19.19s %<ty>-10.10s %<mo>-8.8s %<pr>8.2f %<vl>10.4f %<co>13.2f',
88
101
  ky: idx,
89
- dt: Time.at(htx[:time]),
102
+ dt: htx[:time].strftime('%F %T'),
90
103
  ty: "#{htx[:type]}/#{htx[:ordertype]}",
91
- mo: htx[:pair].upcase,
92
- pr: htx[:price].to_d,
93
- vl: htx[:vol].to_d,
94
- co: htx[:cost].to_d
104
+ mo: htx[:pair],
105
+ pr: htx[:price],
106
+ vl: htx[:vol],
107
+ co: htx[:cost]
95
108
  )
96
109
  end
97
110
 
@@ -102,11 +115,11 @@ module Cns
102
115
  format(
103
116
  '%<ky>-6.6s %<dt>19.19s %<ty>-10.10s %<mo>-4.4s %<pr>18.7f %<vl>18.7f',
104
117
  ky: idx,
105
- dt: Time.at(hlx[:time]),
118
+ dt: hlx[:time].strftime('%F %T'),
106
119
  ty: hlx[:type],
107
- mo: hlx[:asset].upcase,
108
- pr: hlx[:amount].to_d,
109
- vl: hlx[:fee].to_d
120
+ mo: hlx[:asset],
121
+ pr: hlx[:amount],
122
+ vl: hlx[:fee]
110
123
  )
111
124
  end
112
125
 
@@ -126,7 +139,7 @@ module Cns
126
139
  return unless ops[:v] && novcust.count.positive?
127
140
 
128
141
  puts("\ntrade data hora tipo par preco volume custo")
129
- novcust.sort { |ant, prx| prx[1][:time] <=> ant[1][:time] }.each { |key, val| puts(formata_trades(key, val)) }
142
+ novcust.sort_by { |itm| -itm[1][:srx] }.each { |key, val| puts(formata_trades(key, val)) }
130
143
  end
131
144
 
132
145
  # @return [String] texto transacoes ledger
@@ -134,7 +147,22 @@ module Cns
134
147
  return unless ops[:v] && novcusl.count.positive?
135
148
 
136
149
  puts("\nledger data hora tipo moeda quantidade custo")
137
- novcusl.sort { |ant, prx| prx[1][:time] <=> ant[1][:time] }.each { |key, val| puts(formata_ledger(key, val)) }
150
+ novcusl.sort_by { |itm| -itm[1][:srx] }.each { |key, val| puts(formata_ledger(key, val)) }
151
+ end
152
+
153
+ # Processa os trades para garantir que as datas estejam no formato correto
154
+ def pusa(itm)
155
+ itm.select { |key, _| EM.include?(key) }.transform_values { |val| val.to_d }
156
+ end
157
+
158
+ # Processa os trades para garantir que as datas estejam no formato correto
159
+ def pust(itm)
160
+ itm.transform_values { |t| t.merge(srx: (tym = Integer(t[:time])), time: Time.at(tym), pair: t[:pair].upcase, price: t[:price].to_d, vol: t[:vol].to_d, cost: t[:cost].to_d) }
161
+ end
162
+
163
+ # Processa os ledger entries para garantir que as datas estejam no formato correto
164
+ def pusl(itm)
165
+ itm.transform_values { |t| t.merge(srx: (tym = Integer(t[:time])), time: Time.at(tym), asset: t[:asset].upcase, amount: t[:amount].to_d, fee: t[:fee].to_d) }
138
166
  end
139
167
  end
140
168
  end
data/lib/cns/version.rb CHANGED
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Cns
4
- VERSION = '0.8.7'
4
+ VERSION = '0.8.9'
5
5
  end
metadata CHANGED
@@ -1,13 +1,13 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: cns
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.8.7
4
+ version: 0.8.9
5
5
  platform: ruby
6
6
  authors:
7
7
  - Hernâni Rodrigues Vaz
8
8
  bindir: exe
9
9
  cert_chain: []
10
- date: 2025-02-24 00:00:00.000000000 Z
10
+ date: 2025-02-25 00:00:00.000000000 Z
11
11
  dependencies:
12
12
  - !ruby/object:Gem::Dependency
13
13
  name: bundler