block_io 1.0.8 → 3.0.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.appveyor.yml-disabled +26 -0
- data/.gitignore +5 -1
- data/.rspec +1 -0
- data/.travis.yml +14 -0
- data/LICENSE +1 -1
- data/README.md +23 -13
- data/block_io.gemspec +9 -9
- data/examples/basic.rb +38 -10
- data/examples/dtrust.rb +60 -42
- data/examples/proxy.rb +36 -0
- data/examples/sweeper.rb +24 -14
- data/lib/block_io.rb +16 -408
- data/lib/block_io/api_exception.rb +11 -0
- data/lib/block_io/chainparams/BTC.yml +8 -0
- data/lib/block_io/chainparams/BTCTEST.yml +8 -0
- data/lib/block_io/chainparams/DOGE.yml +8 -0
- data/lib/block_io/chainparams/DOGETEST.yml +8 -0
- data/lib/block_io/chainparams/LTC.yml +8 -0
- data/lib/block_io/chainparams/LTCTEST.yml +8 -0
- data/lib/block_io/client.rb +244 -0
- data/lib/block_io/extended_bitcoinrb.rb +127 -0
- data/lib/block_io/helper.rb +322 -0
- data/lib/block_io/key.rb +38 -0
- data/lib/block_io/version.rb +1 -1
- data/spec/client_misc_spec.rb +76 -0
- data/spec/client_spec.rb +68 -0
- data/spec/dtrust_spec.rb +167 -0
- data/spec/helper_spec.rb +154 -0
- data/spec/key_spec.rb +92 -0
- data/spec/larger_transaction_spec.rb +351 -0
- data/spec/spec_helper.rb +5 -0
- data/spec/sweep_spec.rb +115 -0
- data/spec/test-cases/.gitignore +2 -0
- data/spec/test-cases/LICENSE +21 -0
- data/spec/test-cases/README.md +2 -0
- data/spec/test-cases/json/create_and_sign_transaction_response.json +61 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_P2WSH-over-P2SH_1of2_251inputs.json +1261 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_P2WSH-over-P2SH_1of2_252inputs.json +1266 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_P2WSH-over-P2SH_1of2_253inputs.json +1271 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_P2WSH-over-P2SH_1of2_762inputs.json +3816 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2SH_3of5_195inputs.json +2931 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2SH_4of5_195inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2WSH-over-P2SH_3of5_251inputs.json +3771 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2WSH-over-P2SH_3of5_252inputs.json +3786 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2WSH-over-P2SH_3of5_253inputs.json +3801 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2WSH-over-P2SH_4of5_251inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2WSH-over-P2SH_4of5_252inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_P2WSH-over-P2SH_4of5_253inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_WITNESS_V0_3of5_251inputs.json +3771 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_WITNESS_V0_3of5_252inputs.json +3786 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_WITNESS_V0_3of5_253inputs.json +3801 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_WITNESS_V0_4of5_251inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_WITNESS_V0_4of5_252inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_WITNESS_V0_4of5_253inputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_p2sh_3_of_5_keys.json +21 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_p2sh_4_of_5_keys.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_p2wsh_over_p2sh_3_of_5_keys.json +21 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_p2wsh_over_p2sh_4_of_5_keys.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_3_of_5_keys.json +36 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_3of5_251outputs.json +591 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_3of5_252outputs.json +576 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_3of5_253outputs.json +531 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_4_of_5_keys.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_4of5_251outputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_4of5_252outputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_dtrust_witness_v0_4of5_253outputs.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_sweep_p2pkh.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_sweep_p2wpkh.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_sweep_p2wpkh_over_p2sh.json +5 -0
- data/spec/test-cases/json/create_and_sign_transaction_response_with_blockio_fee_and_expected_unsigned_txid.json +21 -0
- data/spec/test-cases/json/get_balance_response.json +8 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2SH_3of5_195inputs.json +1397 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2SH_4of5_195inputs.json +1397 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2WSH-over-P2SH_3of5_251inputs.json +1795 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2WSH-over-P2SH_3of5_252inputs.json +1802 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2WSH-over-P2SH_3of5_253inputs.json +1809 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2WSH-over-P2SH_4of5_251inputs.json +1789 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2WSH-over-P2SH_4of5_252inputs.json +1802 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_P2WSH-over-P2SH_4of5_253inputs.json +1809 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_WITNESS_V0_3of5_251inputs.json +1795 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_WITNESS_V0_3of5_252inputs.json +1802 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_WITNESS_V0_3of5_253inputs.json +1809 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_WITNESS_V0_4of5_251inputs.json +1795 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_WITNESS_V0_4of5_252inputs.json +1802 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_WITNESS_V0_4of5_253inputs.json +1809 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_p2sh.json +45 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_p2wsh_over_p2sh.json +45 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0.json +52 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0_3of5_251outputs.json +1805 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0_3of5_252outputs.json +1804 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0_3of5_253outputs.json +1789 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0_4of5_251outputs.json +1805 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0_4of5_252outputs.json +1804 -0
- data/spec/test-cases/json/prepare_dtrust_transaction_response_witness_v0_4of5_253outputs.json +1789 -0
- data/spec/test-cases/json/prepare_sweep_transaction_response_p2pkh.json +35 -0
- data/spec/test-cases/json/prepare_sweep_transaction_response_p2wpkh.json +35 -0
- data/spec/test-cases/json/prepare_sweep_transaction_response_p2wpkh_over_p2sh.json +35 -0
- data/spec/test-cases/json/prepare_transaction_response.json +164 -0
- data/spec/test-cases/json/prepare_transaction_response_P2WSH-over-P2SH_1of2_251inputs.json +1796 -0
- data/spec/test-cases/json/prepare_transaction_response_P2WSH-over-P2SH_1of2_252inputs.json +1803 -0
- data/spec/test-cases/json/prepare_transaction_response_P2WSH-over-P2SH_1of2_253inputs.json +1810 -0
- data/spec/test-cases/json/prepare_transaction_response_P2WSH-over-P2SH_1of2_762inputs.json +5367 -0
- data/spec/test-cases/json/prepare_transaction_response_with_blockio_fee_and_expected_unsigned_txid.json +76 -0
- data/spec/test-cases/json/summarize_prepared_transaction_response_with_blockio_fee_and_expected_unsigned_txid.json +6 -0
- metadata +264 -73
- data/examples/change.rb +0 -117
data/examples/change.rb
DELETED
@@ -1,117 +0,0 @@
|
|
1
|
-
# 1. create an address (first_address), move all coins to it
|
2
|
-
# 2. create an address (second_address), as the change address for the first_address
|
3
|
-
# 3. send destination_amount to destination_address from first_address, and the rest of the coins to second_address
|
4
|
-
# 4. archive first_address since it will no longer be used
|
5
|
-
|
6
|
-
# execute with:
|
7
|
-
# $ DESTINATION_ADDRESS=AN_ADDRESS DESTINATION_AMOUNT=COINS_TO_SEND_TO_DESTINATION_ADDRESS API_KEY=TESTNET_API_KEY PIN=YOUR_SECRET_PIN ruby change.rb
|
8
|
-
|
9
|
-
require 'block_io'
|
10
|
-
require 'securerandom'
|
11
|
-
require 'bigdecimal'
|
12
|
-
|
13
|
-
# please use the Dogecoin/Bitcoin Testnet API key here
|
14
|
-
BlockIo.set_options :api_key => ENV['API_KEY'], :pin => ENV['PIN'], :version => 2
|
15
|
-
|
16
|
-
# create address A, and withdraw all coins to address A
|
17
|
-
first_address_label = SecureRandom.hex(8) # the source address
|
18
|
-
second_address_label = SecureRandom.hex(8) # the change address
|
19
|
-
|
20
|
-
# let's fill up the first address with whatever coins exist in this account
|
21
|
-
puts BlockIo.get_new_address(:label => first_address_label)
|
22
|
-
|
23
|
-
available_balance = BigDecimal(BlockIo.get_balance()['data']['available_balance'])
|
24
|
-
network_fee = BigDecimal('0.0')
|
25
|
-
|
26
|
-
puts "Available Balance: #{available_balance.truncate(8).to_s('F')}"
|
27
|
-
|
28
|
-
options = {:to_labels => first_address_label, :amounts => available_balance.to_s("F")}
|
29
|
-
|
30
|
-
tries = 2 # retry twice at most
|
31
|
-
|
32
|
-
begin
|
33
|
-
options[:amounts] = (available_balance - network_fee).truncate(8).to_s("F")
|
34
|
-
|
35
|
-
response = BlockIo.get_network_fee_estimate(options)
|
36
|
-
network_fee = BigDecimal(response['data']['estimated_network_fee'])
|
37
|
-
|
38
|
-
puts "Final Network Fee: #{network_fee.truncate(8).to_s('F')}"
|
39
|
-
|
40
|
-
options[:amounts] = (available_balance - network_fee).truncate(8).to_s("F")
|
41
|
-
rescue Exception => e
|
42
|
-
# extract the fee and subtract it from the available amount
|
43
|
-
|
44
|
-
network_fee = BigDecimal(e.to_s.split(' ')[7])
|
45
|
-
puts "Estimated Network Fee: #{e.to_s.split(' ')[7]}"
|
46
|
-
|
47
|
-
retry unless (tries -= 1).zero?
|
48
|
-
|
49
|
-
raise Exception.new("UNABLE TO ESTIMATE NETWORK FEE")
|
50
|
-
end
|
51
|
-
|
52
|
-
# make the withdrawal
|
53
|
-
puts BlockIo.withdraw(options)
|
54
|
-
|
55
|
-
# all balance has been transferred to first_address_label
|
56
|
-
|
57
|
-
# create the change address
|
58
|
-
puts BlockIo.get_new_address(:label => second_address_label)
|
59
|
-
|
60
|
-
destination_address = ENV['DESTINATION_ADDRESS']
|
61
|
-
destination_amount = BigDecimal(ENV['DESTINATION_AMOUNT'])
|
62
|
-
|
63
|
-
puts "Sending #{destination_amount} to #{destination_address}"
|
64
|
-
|
65
|
-
available_balance = BigDecimal(BlockIo.get_balance(:labels => first_address_label)['data']['available_balance'])
|
66
|
-
|
67
|
-
second_address = BlockIo.get_address_by_label(:label => second_address_label)['data']['address']
|
68
|
-
|
69
|
-
options = {}
|
70
|
-
|
71
|
-
tries = 2 # two tries to estimate the correct network fee
|
72
|
-
|
73
|
-
network_fee = BigDecimal('0.0')
|
74
|
-
|
75
|
-
to_addresses = []
|
76
|
-
amounts = []
|
77
|
-
|
78
|
-
# estimate the fee for this withdrawal
|
79
|
-
begin
|
80
|
-
|
81
|
-
change_amount = available_balance - destination_amount
|
82
|
-
|
83
|
-
if change_amount - network_fee > 0 then
|
84
|
-
to_addresses = [destination_address, second_address]
|
85
|
-
amounts = [destination_amount.truncate(8).to_s("F"), (change_amount - network_fee).truncate(8).to_s("F")]
|
86
|
-
else
|
87
|
-
to_addresses = [destination_address]
|
88
|
-
amounts = [destination_amount.truncate(8).to_s("F")]
|
89
|
-
end
|
90
|
-
|
91
|
-
response = BlockIo.get_network_fee_estimate(:from_labels => first_address_label, :to_addresses => to_addresses.join(','), :amounts => amounts.join(','))
|
92
|
-
network_fee = BigDecimal(response['data']['estimated_network_fee'])
|
93
|
-
|
94
|
-
puts "Final Network Fee: #{network_fee.truncate(8).to_s('F')}"
|
95
|
-
|
96
|
-
rescue Exception => e
|
97
|
-
# extract the fee and subtract it from the available amount
|
98
|
-
|
99
|
-
puts "Exception: #{e.to_s}"
|
100
|
-
|
101
|
-
network_fee = BigDecimal(e.to_s.split(' ')[7])
|
102
|
-
puts "Estimated Network Fee: #{e.to_s.split(' ')[7]}"
|
103
|
-
|
104
|
-
retry unless (tries -= 1).zero?
|
105
|
-
|
106
|
-
raise Exception.new("UNABLE TO ESTIMATE NETWORK FEE")
|
107
|
-
end
|
108
|
-
|
109
|
-
# make the withdrawal + send change to change address
|
110
|
-
|
111
|
-
puts BlockIo.withdraw(:from_labels => first_address_label, :to_addresses => to_addresses.join(','), :amounts => amounts.join(','))
|
112
|
-
|
113
|
-
# archive the first address
|
114
|
-
|
115
|
-
puts BlockIo.archive_address(:labels => first_address_label)
|
116
|
-
|
117
|
-
|