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 +4 -4
- data/Gemfile.lock +1 -1
- data/lib/cns/bigquery.rb +25 -23
- data/lib/cns/bitcoinde.rb +62 -19
- data/lib/cns/etherscan.rb +48 -76
- data/lib/cns/greymass.rb +44 -35
- data/lib/cns/kraken.rb +49 -21
- data/lib/cns/version.rb +1 -1
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: aa9737420761247a9d82111220ba71741c591fa08fe035da2f8f4717cd8b179d
|
4
|
+
data.tar.gz: 6e5b7f03930de50c278a0a1d0a6442b6535c67bfa1874f0402b2c4075c363108
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 92144b9670390bf051d131f2bdf1b35a8c475ac16fa935dc2f6bb37b04298a5304ceadceeac467da687d70e847ee5cfc3974d6deca8519b8a368c3bec446334d
|
7
|
+
data.tar.gz: 1f519cc3912a0ea47d1cabb557eb191c04dafd6dc308d08da23969ae2fc604f720f3441844c277b1259f446a20aad28645ccf4868d6c5e795efeef17e7f5ef97
|
data/Gemfile.lock
CHANGED
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
|
-
|
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[:
|
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(
|
375
|
-
fqt(
|
376
|
-
fqt(
|
377
|
-
fqt(
|
377
|
+
fqt(htx[:account]),
|
378
|
+
fqt(htx[:name]),
|
379
|
+
fqt(htx[:from]),
|
380
|
+
fqt(htx[:to]),
|
378
381
|
fqt(htx[:iax]),
|
379
|
-
fnm(
|
380
|
-
fqt(
|
381
|
-
fqt(
|
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]
|
411
|
-
fqt(
|
411
|
+
fts(htx[:time]),
|
412
|
+
fqt(htx[:tp]),
|
412
413
|
fqt(htx[:add]),
|
413
414
|
fqt(htx[:moe]),
|
414
|
-
fnm(
|
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
|
-
|
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]),
|
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
|
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
|
-
|
52
|
-
|
53
|
-
|
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] }
|
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] }
|
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
|
71
|
-
vex = hsx[:total_amount]
|
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:
|
88
|
-
dp:
|
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]
|
91
|
-
vl: htx[:amount_currency_to_trade]
|
92
|
-
co: htx[:volume_currency_to_pay]
|
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]
|
105
|
-
pr: hlx[:qt]
|
106
|
-
vl: hlx[:fee]
|
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.
|
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.
|
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:
|
108
|
-
tx:
|
109
|
-
ix:
|
110
|
-
px:
|
111
|
-
wx:
|
112
|
-
kx:
|
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.
|
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.
|
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.
|
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.
|
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.
|
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
|
-
|
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:
|
313
|
-
vl:
|
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:
|
327
|
-
vl:
|
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:
|
341
|
-
vl:
|
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:
|
138
|
-
fr:
|
139
|
-
vl:
|
112
|
+
ac: hlx[:name],
|
113
|
+
fr: hlx[:from],
|
114
|
+
vl: hlx[:quantity],
|
140
115
|
bn: hlx[:itx],
|
141
|
-
to:
|
142
|
-
dt:
|
143
|
-
sy:
|
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
|
-
|
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=#{
|
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
|
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
|
-
|
52
|
-
|
53
|
-
|
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 -
|
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 -
|
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
|
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:
|
89
|
+
kr: sal,
|
77
90
|
bq: vbq,
|
78
|
-
ok: vbq ==
|
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:
|
102
|
+
dt: htx[:time].strftime('%F %T'),
|
90
103
|
ty: "#{htx[:type]}/#{htx[:ordertype]}",
|
91
|
-
mo: htx[:pair]
|
92
|
-
pr: htx[:price]
|
93
|
-
vl: htx[:vol]
|
94
|
-
co: htx[:cost]
|
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:
|
118
|
+
dt: hlx[:time].strftime('%F %T'),
|
106
119
|
ty: hlx[:type],
|
107
|
-
mo: hlx[:asset]
|
108
|
-
pr: hlx[:amount]
|
109
|
-
vl: hlx[:fee]
|
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.
|
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.
|
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
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.
|
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-
|
10
|
+
date: 2025-02-25 00:00:00.000000000 Z
|
11
11
|
dependencies:
|
12
12
|
- !ruby/object:Gem::Dependency
|
13
13
|
name: bundler
|