bitcoinrb 0.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (86) hide show
  1. checksums.yaml +7 -0
  2. data/.gitignore +9 -0
  3. data/.rspec +2 -0
  4. data/.ruby-gemset +1 -0
  5. data/.ruby-version +1 -0
  6. data/.travis.yml +4 -0
  7. data/CODE_OF_CONDUCT.md +49 -0
  8. data/Gemfile +4 -0
  9. data/LICENSE.txt +21 -0
  10. data/README.md +41 -0
  11. data/Rakefile +6 -0
  12. data/bin/console +14 -0
  13. data/bin/setup +8 -0
  14. data/bitcoinrb.gemspec +32 -0
  15. data/exe/bitcoinrb-cli +5 -0
  16. data/exe/bitcoinrbd +49 -0
  17. data/lib/bitcoin.rb +121 -0
  18. data/lib/bitcoin/base58.rb +40 -0
  19. data/lib/bitcoin/block_header.rb +41 -0
  20. data/lib/bitcoin/chain_params.rb +57 -0
  21. data/lib/bitcoin/chainparams/mainnet.yml +25 -0
  22. data/lib/bitcoin/chainparams/regtest.yml +20 -0
  23. data/lib/bitcoin/chainparams/testnet.yml +24 -0
  24. data/lib/bitcoin/connection.rb +66 -0
  25. data/lib/bitcoin/ext_key.rb +205 -0
  26. data/lib/bitcoin/key.rb +131 -0
  27. data/lib/bitcoin/logger.rb +18 -0
  28. data/lib/bitcoin/merkle_tree.rb +120 -0
  29. data/lib/bitcoin/message.rb +42 -0
  30. data/lib/bitcoin/message/addr.rb +74 -0
  31. data/lib/bitcoin/message/base.rb +40 -0
  32. data/lib/bitcoin/message/block.rb +41 -0
  33. data/lib/bitcoin/message/error.rb +10 -0
  34. data/lib/bitcoin/message/fee_filter.rb +27 -0
  35. data/lib/bitcoin/message/filter_add.rb +28 -0
  36. data/lib/bitcoin/message/filter_clear.rb +17 -0
  37. data/lib/bitcoin/message/filter_load.rb +43 -0
  38. data/lib/bitcoin/message/get_addr.rb +17 -0
  39. data/lib/bitcoin/message/get_blocks.rb +29 -0
  40. data/lib/bitcoin/message/get_data.rb +21 -0
  41. data/lib/bitcoin/message/get_headers.rb +28 -0
  42. data/lib/bitcoin/message/handler.rb +170 -0
  43. data/lib/bitcoin/message/headers.rb +34 -0
  44. data/lib/bitcoin/message/headers_parser.rb +24 -0
  45. data/lib/bitcoin/message/inv.rb +21 -0
  46. data/lib/bitcoin/message/inventories_parser.rb +23 -0
  47. data/lib/bitcoin/message/inventory.rb +47 -0
  48. data/lib/bitcoin/message/mem_pool.rb +17 -0
  49. data/lib/bitcoin/message/merkle_block.rb +42 -0
  50. data/lib/bitcoin/message/not_found.rb +29 -0
  51. data/lib/bitcoin/message/ping.rb +30 -0
  52. data/lib/bitcoin/message/pong.rb +26 -0
  53. data/lib/bitcoin/message/reject.rb +46 -0
  54. data/lib/bitcoin/message/send_cmpct.rb +43 -0
  55. data/lib/bitcoin/message/send_headers.rb +16 -0
  56. data/lib/bitcoin/message/tx.rb +30 -0
  57. data/lib/bitcoin/message/ver_ack.rb +17 -0
  58. data/lib/bitcoin/message/version.rb +79 -0
  59. data/lib/bitcoin/mnemonic.rb +76 -0
  60. data/lib/bitcoin/mnemonic/wordlist/chinese_simplified.txt +2048 -0
  61. data/lib/bitcoin/mnemonic/wordlist/chinese_traditional.txt +2048 -0
  62. data/lib/bitcoin/mnemonic/wordlist/english.txt +2048 -0
  63. data/lib/bitcoin/mnemonic/wordlist/french.txt +2048 -0
  64. data/lib/bitcoin/mnemonic/wordlist/italian.txt +2048 -0
  65. data/lib/bitcoin/mnemonic/wordlist/japanese.txt +2048 -0
  66. data/lib/bitcoin/mnemonic/wordlist/spanish.txt +2048 -0
  67. data/lib/bitcoin/nodes.rb +5 -0
  68. data/lib/bitcoin/nodes/spv.rb +13 -0
  69. data/lib/bitcoin/nodes/spv/cli.rb +12 -0
  70. data/lib/bitcoin/nodes/spv/daemon.rb +21 -0
  71. data/lib/bitcoin/opcodes.rb +172 -0
  72. data/lib/bitcoin/out_point.rb +31 -0
  73. data/lib/bitcoin/script/script.rb +347 -0
  74. data/lib/bitcoin/script/script_error.rb +168 -0
  75. data/lib/bitcoin/script/script_interpreter.rb +694 -0
  76. data/lib/bitcoin/script/tx_checker.rb +44 -0
  77. data/lib/bitcoin/script_witness.rb +29 -0
  78. data/lib/bitcoin/secp256k1.rb +10 -0
  79. data/lib/bitcoin/secp256k1/native.rb +22 -0
  80. data/lib/bitcoin/secp256k1/ruby.rb +96 -0
  81. data/lib/bitcoin/tx.rb +191 -0
  82. data/lib/bitcoin/tx_in.rb +45 -0
  83. data/lib/bitcoin/tx_out.rb +32 -0
  84. data/lib/bitcoin/util.rb +105 -0
  85. data/lib/bitcoin/version.rb +3 -0
  86. metadata +256 -0
@@ -0,0 +1,105 @@
1
+ module Bitcoin
2
+
3
+ # bitcoin utility.
4
+ # following methods can be used as follows.
5
+ # Bitcoin.pack_var_int(5)
6
+ module Util
7
+
8
+ def pack_var_string(payload)
9
+ pack_var_int(payload.bytesize) + payload
10
+ end
11
+
12
+ def unpack_var_string(payload)
13
+ size, payload = unpack_var_int(payload)
14
+ size > 0 ? payload.unpack("a#{size}a*") : [nil, payload]
15
+ end
16
+
17
+ def pack_var_int(i)
18
+ if i < 0xfd
19
+ [i].pack('C')
20
+ elsif i <= 0xffff
21
+ [0xfd, i].pack('Cv')
22
+ elsif i <= 0xffffffff
23
+ [0xfe, i].pack('CV')
24
+ elsif i <= 0xffffffffffffffff
25
+ [0xff, i].pack('CQ')
26
+ else
27
+ raise "int(#{i}) too large!"
28
+ end
29
+ end
30
+
31
+ def unpack_var_int(payload)
32
+ case payload.unpack('C').first
33
+ when 0xfd
34
+ payload.unpack('xva*')
35
+ when 0xfe
36
+ payload.unpack('xVa*')
37
+ when 0xff
38
+ payload.unpack('xQa*')
39
+ else
40
+ payload.unpack('Ca*')
41
+ end
42
+ end
43
+
44
+ def unpack_var_int_from_io(buf)
45
+ uchar = buf.read(1).unpack('C').first
46
+ case uchar
47
+ when 0xfd
48
+ buf.read(2).unpack('v').first
49
+ when 0xfe
50
+ buf.read(4).unpack('V').first
51
+ when 0xff
52
+ buf.read(8).unpack('Q').first
53
+ else
54
+ uchar
55
+ end
56
+ end
57
+
58
+ def pack_boolean(b)
59
+ b ? [0xFF].pack('C') : [0x00].pack('C')
60
+ end
61
+
62
+ def unpack_boolean(payload)
63
+ data, payload = payload.unpack('Ca*')
64
+ [(data.zero? ? false : true), payload]
65
+ end
66
+
67
+ def sha256(payload)
68
+ Digest::SHA256.digest(payload)
69
+ end
70
+
71
+ def double_sha256(payload)
72
+ sha256(sha256(payload))
73
+ end
74
+
75
+ # byte convert to the sequence of bits packed eight in a byte with the least significant bit first.
76
+ def byte_to_bit(byte)
77
+ byte.unpack('b*').first
78
+ end
79
+
80
+ # generate sha256-ripemd160 hash for value
81
+ def hash160(hex)
82
+ Digest::RMD160.hexdigest(Digest::SHA256.digest(hex.htb))
83
+ end
84
+
85
+ def encode_base58_address(hex)
86
+ Base58.encode(hex + calc_checksum(hex))
87
+ end
88
+
89
+ def decode_base58_address(addr)
90
+ Base58.decode(addr)
91
+ end
92
+
93
+ def calc_checksum(hex)
94
+ double_sha256(hex.htb).bth[0..7]
95
+ end
96
+
97
+ DIGEST_NAME_SHA256 = 'sha256'
98
+
99
+ def hmac_sha256(key, data)
100
+ OpenSSL::HMAC.digest(DIGEST_NAME_SHA256, key, data)
101
+ end
102
+
103
+ end
104
+
105
+ end
@@ -0,0 +1,3 @@
1
+ module Bitcoin
2
+ VERSION = "0.0.1"
3
+ end
metadata ADDED
@@ -0,0 +1,256 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: bitcoinrb
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - azuchi
8
+ autorequire:
9
+ bindir: exe
10
+ cert_chain: []
11
+ date: 2017-08-25 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: ecdsa
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - ">="
18
+ - !ruby/object:Gem::Version
19
+ version: '0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - ">="
25
+ - !ruby/object:Gem::Version
26
+ version: '0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: eventmachine
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - ">="
32
+ - !ruby/object:Gem::Version
33
+ version: '0'
34
+ type: :runtime
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ - !ruby/object:Gem::Dependency
42
+ name: murmurhash3
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - ">="
46
+ - !ruby/object:Gem::Version
47
+ version: '0'
48
+ type: :runtime
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - ">="
53
+ - !ruby/object:Gem::Version
54
+ version: '0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: bech32
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: 1.0.1
62
+ type: :runtime
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: 1.0.1
69
+ - !ruby/object:Gem::Dependency
70
+ name: daemon-spawn
71
+ requirement: !ruby/object:Gem::Requirement
72
+ requirements:
73
+ - - ">="
74
+ - !ruby/object:Gem::Version
75
+ version: '0'
76
+ type: :runtime
77
+ prerelease: false
78
+ version_requirements: !ruby/object:Gem::Requirement
79
+ requirements:
80
+ - - ">="
81
+ - !ruby/object:Gem::Version
82
+ version: '0'
83
+ - !ruby/object:Gem::Dependency
84
+ name: thor
85
+ requirement: !ruby/object:Gem::Requirement
86
+ requirements:
87
+ - - ">="
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ type: :runtime
91
+ prerelease: false
92
+ version_requirements: !ruby/object:Gem::Requirement
93
+ requirements:
94
+ - - ">="
95
+ - !ruby/object:Gem::Version
96
+ version: '0'
97
+ - !ruby/object:Gem::Dependency
98
+ name: bundler
99
+ requirement: !ruby/object:Gem::Requirement
100
+ requirements:
101
+ - - "~>"
102
+ - !ruby/object:Gem::Version
103
+ version: '1.11'
104
+ type: :development
105
+ prerelease: false
106
+ version_requirements: !ruby/object:Gem::Requirement
107
+ requirements:
108
+ - - "~>"
109
+ - !ruby/object:Gem::Version
110
+ version: '1.11'
111
+ - !ruby/object:Gem::Dependency
112
+ name: rake
113
+ requirement: !ruby/object:Gem::Requirement
114
+ requirements:
115
+ - - "~>"
116
+ - !ruby/object:Gem::Version
117
+ version: '10.0'
118
+ type: :development
119
+ prerelease: false
120
+ version_requirements: !ruby/object:Gem::Requirement
121
+ requirements:
122
+ - - "~>"
123
+ - !ruby/object:Gem::Version
124
+ version: '10.0'
125
+ - !ruby/object:Gem::Dependency
126
+ name: rspec
127
+ requirement: !ruby/object:Gem::Requirement
128
+ requirements:
129
+ - - "~>"
130
+ - !ruby/object:Gem::Version
131
+ version: '3.0'
132
+ type: :development
133
+ prerelease: false
134
+ version_requirements: !ruby/object:Gem::Requirement
135
+ requirements:
136
+ - - "~>"
137
+ - !ruby/object:Gem::Version
138
+ version: '3.0'
139
+ description: "[WIP]The implementation of Bitcoin Protocol for Ruby."
140
+ email:
141
+ - azuchi@haw.co.jp
142
+ executables:
143
+ - bitcoinrb-cli
144
+ - bitcoinrbd
145
+ extensions: []
146
+ extra_rdoc_files: []
147
+ files:
148
+ - ".gitignore"
149
+ - ".rspec"
150
+ - ".ruby-gemset"
151
+ - ".ruby-version"
152
+ - ".travis.yml"
153
+ - CODE_OF_CONDUCT.md
154
+ - Gemfile
155
+ - LICENSE.txt
156
+ - README.md
157
+ - Rakefile
158
+ - bin/console
159
+ - bin/setup
160
+ - bitcoinrb.gemspec
161
+ - exe/bitcoinrb-cli
162
+ - exe/bitcoinrbd
163
+ - lib/bitcoin.rb
164
+ - lib/bitcoin/base58.rb
165
+ - lib/bitcoin/block_header.rb
166
+ - lib/bitcoin/chain_params.rb
167
+ - lib/bitcoin/chainparams/mainnet.yml
168
+ - lib/bitcoin/chainparams/regtest.yml
169
+ - lib/bitcoin/chainparams/testnet.yml
170
+ - lib/bitcoin/connection.rb
171
+ - lib/bitcoin/ext_key.rb
172
+ - lib/bitcoin/key.rb
173
+ - lib/bitcoin/logger.rb
174
+ - lib/bitcoin/merkle_tree.rb
175
+ - lib/bitcoin/message.rb
176
+ - lib/bitcoin/message/addr.rb
177
+ - lib/bitcoin/message/base.rb
178
+ - lib/bitcoin/message/block.rb
179
+ - lib/bitcoin/message/error.rb
180
+ - lib/bitcoin/message/fee_filter.rb
181
+ - lib/bitcoin/message/filter_add.rb
182
+ - lib/bitcoin/message/filter_clear.rb
183
+ - lib/bitcoin/message/filter_load.rb
184
+ - lib/bitcoin/message/get_addr.rb
185
+ - lib/bitcoin/message/get_blocks.rb
186
+ - lib/bitcoin/message/get_data.rb
187
+ - lib/bitcoin/message/get_headers.rb
188
+ - lib/bitcoin/message/handler.rb
189
+ - lib/bitcoin/message/headers.rb
190
+ - lib/bitcoin/message/headers_parser.rb
191
+ - lib/bitcoin/message/inv.rb
192
+ - lib/bitcoin/message/inventories_parser.rb
193
+ - lib/bitcoin/message/inventory.rb
194
+ - lib/bitcoin/message/mem_pool.rb
195
+ - lib/bitcoin/message/merkle_block.rb
196
+ - lib/bitcoin/message/not_found.rb
197
+ - lib/bitcoin/message/ping.rb
198
+ - lib/bitcoin/message/pong.rb
199
+ - lib/bitcoin/message/reject.rb
200
+ - lib/bitcoin/message/send_cmpct.rb
201
+ - lib/bitcoin/message/send_headers.rb
202
+ - lib/bitcoin/message/tx.rb
203
+ - lib/bitcoin/message/ver_ack.rb
204
+ - lib/bitcoin/message/version.rb
205
+ - lib/bitcoin/mnemonic.rb
206
+ - lib/bitcoin/mnemonic/wordlist/chinese_simplified.txt
207
+ - lib/bitcoin/mnemonic/wordlist/chinese_traditional.txt
208
+ - lib/bitcoin/mnemonic/wordlist/english.txt
209
+ - lib/bitcoin/mnemonic/wordlist/french.txt
210
+ - lib/bitcoin/mnemonic/wordlist/italian.txt
211
+ - lib/bitcoin/mnemonic/wordlist/japanese.txt
212
+ - lib/bitcoin/mnemonic/wordlist/spanish.txt
213
+ - lib/bitcoin/nodes.rb
214
+ - lib/bitcoin/nodes/spv.rb
215
+ - lib/bitcoin/nodes/spv/cli.rb
216
+ - lib/bitcoin/nodes/spv/daemon.rb
217
+ - lib/bitcoin/opcodes.rb
218
+ - lib/bitcoin/out_point.rb
219
+ - lib/bitcoin/script/script.rb
220
+ - lib/bitcoin/script/script_error.rb
221
+ - lib/bitcoin/script/script_interpreter.rb
222
+ - lib/bitcoin/script/tx_checker.rb
223
+ - lib/bitcoin/script_witness.rb
224
+ - lib/bitcoin/secp256k1.rb
225
+ - lib/bitcoin/secp256k1/native.rb
226
+ - lib/bitcoin/secp256k1/ruby.rb
227
+ - lib/bitcoin/tx.rb
228
+ - lib/bitcoin/tx_in.rb
229
+ - lib/bitcoin/tx_out.rb
230
+ - lib/bitcoin/util.rb
231
+ - lib/bitcoin/version.rb
232
+ homepage: https://github.com/haw-itn/bitcoinrb
233
+ licenses:
234
+ - MIT
235
+ metadata: {}
236
+ post_install_message:
237
+ rdoc_options: []
238
+ require_paths:
239
+ - lib
240
+ required_ruby_version: !ruby/object:Gem::Requirement
241
+ requirements:
242
+ - - ">="
243
+ - !ruby/object:Gem::Version
244
+ version: '0'
245
+ required_rubygems_version: !ruby/object:Gem::Requirement
246
+ requirements:
247
+ - - ">="
248
+ - !ruby/object:Gem::Version
249
+ version: '0'
250
+ requirements: []
251
+ rubyforge_project:
252
+ rubygems_version: 2.6.11
253
+ signing_key:
254
+ specification_version: 4
255
+ summary: "[WIP]The implementation of Bitcoin Protocol for Ruby."
256
+ test_files: []