block_io 2.0.0 → 3.0.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/{.appveyor.yml → .appveyor.yml-disabled} +2 -2
- data/.gitignore +1 -0
- data/.travis.yml +1 -1
- data/LICENSE +1 -1
- data/README.md +18 -14
- data/block_io.gemspec +7 -7
- data/examples/basic.rb +29 -5
- data/examples/dtrust.rb +43 -24
- data/examples/sweeper.rb +21 -16
- 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 +145 -80
- data/lib/block_io/extended_bitcoinrb.rb +132 -0
- data/lib/block_io/helper.rb +211 -53
- data/lib/block_io/key.rb +11 -124
- data/lib/block_io/version.rb +1 -1
- data/lib/block_io.rb +3 -2
- data/spec/client_misc_spec.rb +76 -0
- data/spec/client_spec.rb +23 -178
- data/spec/dtrust_spec.rb +167 -0
- data/spec/helper_spec.rb +117 -7
- data/spec/key_spec.rb +50 -19
- data/spec/larger_transaction_spec.rb +371 -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/create_and_sign_transaction_response_witness_v1_output.json +11 -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/prepare_transaction_response_witness_v1_output.json +64 -0
- data/spec/test-cases/json/summarize_prepared_transaction_response_with_blockio_fee_and_expected_unsigned_txid.json +6 -0
- metadata +203 -57
- data/examples/max_withdrawal.rb +0 -29
- data/lib/block_io/constants.rb +0 -10
- data/spec/data/sign_and_finalize_dtrust_withdrawal_request.json +0 -1
- data/spec/data/sign_and_finalize_sweep_request.json +0 -1
- data/spec/data/sign_and_finalize_withdrawal_request.json +0 -4
- data/spec/data/sweep_from_address_response.json +0 -1
- data/spec/data/withdraw_from_dtrust_address_response.json +0 -1
- data/spec/data/withdraw_response.json +0 -1227
- data/spec/rfc6979_spec.rb +0 -59
- data/spec/withdraw_spec.rb +0 -90
data/spec/rfc6979_spec.rb
DELETED
@@ -1,59 +0,0 @@
|
|
1
|
-
describe "RFC6979" do
|
2
|
-
|
3
|
-
context "deadbeef" do
|
4
|
-
|
5
|
-
before(:each) do
|
6
|
-
@key = BlockIo::Key.from_passphrase("deadbeef")
|
7
|
-
@data = "e76f0f78b7e7474f04cc14ad1343e4cc28f450399a79457d1240511a054afd63"
|
8
|
-
end
|
9
|
-
|
10
|
-
it "without_extra_entropy" do
|
11
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16)).to_s(16)
|
12
|
-
expect(nonce).to eq("b13fa787e16b878c9a7815c8b508eb9e6a401432a15f340dd3fcde25e5c494b8")
|
13
|
-
end
|
14
|
-
|
15
|
-
it "with_extra_entropy_1" do
|
16
|
-
# Key.deterministicGenerateK([data].pack("H*"), @private_key, counter)
|
17
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16), 1).to_s(16)
|
18
|
-
expect(nonce).to eq("b69b1e880b537aca72b7235506ba04a676bdd2d663e4e1eb7d8c567f48ab0646")
|
19
|
-
end
|
20
|
-
|
21
|
-
it "with_extra_entropy_2" do
|
22
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16), 2).to_s(16)
|
23
|
-
expect(nonce).to eq("e0b71534de1cf4f5019b0bc4e10d655d0e625b531e4911daf44cf2d065dcedd3")
|
24
|
-
end
|
25
|
-
|
26
|
-
it "with_extra_entropy_3" do
|
27
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16), 3).to_s(16)
|
28
|
-
expect(nonce).to eq("faed0d38abb73e5f909cc989d967e3c4abb873ad177fe72bc35dc8ba42452fc0")
|
29
|
-
end
|
30
|
-
|
31
|
-
it "with_extra_entropy_4" do
|
32
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16), 4).to_s(16)
|
33
|
-
expect(nonce).to eq("96db9090ce1eb13ae91fb15129838d73ba382cfeb48f6d1cf1a1296a3ce94c49")
|
34
|
-
end
|
35
|
-
|
36
|
-
it "with_extra_entropy_16" do
|
37
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16),16).to_s(16)
|
38
|
-
expect(nonce).to eq("d4985f135357c3885c55c3dff3e9f98bccb0264fb348259f8160660e41f5ce65")
|
39
|
-
end
|
40
|
-
|
41
|
-
it "with_extra_entropy_17" do
|
42
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16),17).to_s(16)
|
43
|
-
expect(nonce).to eq("1affb74f0ecffa9b1996670ba47c6366dd76b484f7af977e4cd32d16c5545e0d")
|
44
|
-
end
|
45
|
-
|
46
|
-
it "with_extra_entropy_255" do
|
47
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16),255).to_s(16)
|
48
|
-
expect(nonce).to eq("d72decc0d526ece67755680556b8700ccfdd2fd7beba87f709ec4037f7a0771f")
|
49
|
-
end
|
50
|
-
|
51
|
-
it "with_extra_entropy_256" do
|
52
|
-
nonce = BlockIo::Key.send(:deterministicGenerateK, [@data].pack("H*"), @key.private_key.to_i(16),256).to_s(16)
|
53
|
-
expect(nonce).to eq("5ff357395dc803f98967276a49a0802cc5b44b52db395242926bd2c4a6ac062f")
|
54
|
-
end
|
55
|
-
|
56
|
-
end
|
57
|
-
|
58
|
-
end
|
59
|
-
|
data/spec/withdraw_spec.rb
DELETED
@@ -1,90 +0,0 @@
|
|
1
|
-
|
2
|
-
describe "Oj.load_file" do
|
3
|
-
|
4
|
-
context "withdraw_response.json" do
|
5
|
-
|
6
|
-
before(:each) do
|
7
|
-
@data = Oj.load_file("spec/data/withdraw_response.json")
|
8
|
-
end
|
9
|
-
|
10
|
-
it "valid?(data.reference_id)" do
|
11
|
-
expect(@data["data"]["reference_id"]).to eq("25cd8b0ad5cf8987c99e16921149cdb0680b1c1360276b4d652904958b19a8bd")
|
12
|
-
end
|
13
|
-
|
14
|
-
end
|
15
|
-
|
16
|
-
context "sign_and_finalize_withdraw_request.json" do
|
17
|
-
|
18
|
-
before(:each) do
|
19
|
-
@data = Oj.load_file("spec/data/sign_and_finalize_withdrawal_request.json")
|
20
|
-
end
|
21
|
-
|
22
|
-
it ".key?(signature_data)" do
|
23
|
-
expect(@data.key?("signature_data")).to eq(true)
|
24
|
-
end
|
25
|
-
|
26
|
-
it "signature_data.is_a?(String)" do
|
27
|
-
expect(@data["signature_data"].is_a?(String)).to eq(true)
|
28
|
-
end
|
29
|
-
|
30
|
-
end
|
31
|
-
|
32
|
-
end
|
33
|
-
|
34
|
-
describe "Helper.signData" do
|
35
|
-
|
36
|
-
context "bad_key" do
|
37
|
-
|
38
|
-
before(:each) do
|
39
|
-
@bad_key = BlockIo::Key.new(nil, false)
|
40
|
-
@data = Oj.load_file("spec/data/withdraw_response.json")
|
41
|
-
@signatures_added = BlockIo::Helper.signData(@data["data"]["inputs"], [@bad_key])
|
42
|
-
end
|
43
|
-
|
44
|
-
it "signed_data.nil?" do
|
45
|
-
all_signatures_empty = @data["data"]["inputs"].all?{|input| input["signers"].first["signed_data"].nil? }
|
46
|
-
expect(all_signatures_empty).to eq(true)
|
47
|
-
end
|
48
|
-
|
49
|
-
it "!signatures_added?" do
|
50
|
-
expect(@signatures_added).to eq(false)
|
51
|
-
end
|
52
|
-
|
53
|
-
end
|
54
|
-
|
55
|
-
context "key" do
|
56
|
-
|
57
|
-
before(:each) do
|
58
|
-
@data = Oj.load_file("spec/data/withdraw_response.json")
|
59
|
-
@encryption_key = BlockIo::Helper.pinToAesKey("blockiotestpininsecure")
|
60
|
-
@decrypted = BlockIo::Helper.decrypt(@data["data"]["encrypted_passphrase"]["passphrase"], @encryption_key)
|
61
|
-
@key = BlockIo::Key.from_passphrase(@decrypted, false)
|
62
|
-
@bad_key = BlockIo::Key.new(nil, false)
|
63
|
-
@result = Oj.safe_load(Oj.load_file("spec/data/sign_and_finalize_withdrawal_request.json")["signature_data"])["inputs"]
|
64
|
-
@signatures_added = BlockIo::Helper.signData(@data["data"]["inputs"], [@key])
|
65
|
-
end
|
66
|
-
|
67
|
-
it "signatures_added?" do
|
68
|
-
expect(@signatures_added).to eq(true)
|
69
|
-
end
|
70
|
-
|
71
|
-
it "valid_signature?(key)" do
|
72
|
-
all_signatures_valid = @data["data"]["inputs"].all?{|input| @key.valid_signature?(input["signers"].first["signed_data"], input["data_to_sign"]) }
|
73
|
-
expect(all_signatures_valid).to eq(true)
|
74
|
-
end
|
75
|
-
|
76
|
-
it "result.eq?(expected_signed_data)" do
|
77
|
-
matches_signed_data = Oj.dump(@result).eql?(Oj.dump(@data["data"]["inputs"]))
|
78
|
-
expect(matches_signed_data).to eq(true)
|
79
|
-
end
|
80
|
-
|
81
|
-
it "valid_signature?(bad_key)" do
|
82
|
-
all_signatures_invalid = @data["data"]["inputs"].all?{|input|
|
83
|
-
(!input["signers"].first["signed_data"].nil? and
|
84
|
-
!@bad_key.valid_signature?(input["signers"].first["signed_data"], input["data_to_sign"]))
|
85
|
-
}
|
86
|
-
expect(all_signatures_invalid).to eq(true)
|
87
|
-
end
|
88
|
-
|
89
|
-
end
|
90
|
-
end
|