casper_network 0.2.0 → 1.0.0

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.
Files changed (140) hide show
  1. checksums.yaml +4 -4
  2. data/CONTRIBUTING.md +1 -0
  3. data/LICENSE +201 -0
  4. data/README.md +165 -0
  5. data/SECURITY.md +12 -0
  6. data/lib/casper_network.rb +253 -178
  7. data/lib/crypto/00_asymmetric_key.rb +95 -0
  8. data/lib/crypto/01_ed25519.rb +67 -0
  9. data/lib/crypto/asymmetric_key.rb +87 -0
  10. data/lib/crypto/ed25519_key.rb +44 -0
  11. data/lib/crypto/key_pair.rb +40 -0
  12. data/lib/crypto/keys.rb +7 -0
  13. data/lib/crypto/secp256k1_key.rb +0 -0
  14. data/lib/crypto/test_ed25519_key.rb +44 -0
  15. data/lib/entity/account.rb +45 -0
  16. data/lib/entity/action_thresholds.rb +25 -0
  17. data/lib/entity/associated_key.rb +24 -0
  18. data/lib/entity/auction_state.rb +36 -0
  19. data/lib/entity/bid.rb +24 -0
  20. data/lib/entity/bid_info.rb +51 -0
  21. data/lib/entity/contract.rb +47 -0
  22. data/lib/entity/contract_package.rb +41 -0
  23. data/lib/entity/contract_version.rb +33 -0
  24. data/lib/entity/delegator.rb +37 -0
  25. data/lib/entity/deploy.rb +44 -0
  26. data/lib/entity/deploy_approval.rb +24 -0
  27. data/lib/entity/deploy_executable.rb +162 -0
  28. data/lib/entity/deploy_executable_item_internal.rb +26 -0
  29. data/lib/entity/deploy_executable_transfer.rb +50 -0
  30. data/lib/entity/deploy_hash.rb +16 -0
  31. data/lib/entity/deploy_header.rb +60 -0
  32. data/lib/entity/deploy_info.rb +44 -0
  33. data/lib/entity/deploy_named_argument.rb +19 -0
  34. data/lib/entity/deploy_transfer.rb +10 -0
  35. data/lib/entity/disabled_version.rb +26 -0
  36. data/lib/entity/era_info.rb +18 -0
  37. data/lib/entity/era_summary.rb +44 -0
  38. data/lib/entity/era_validator.rb +23 -0
  39. data/lib/entity/executable_deploy_item.rb +11 -0
  40. data/lib/entity/group.rb +25 -0
  41. data/lib/entity/module_bytes.rb +50 -0
  42. data/lib/entity/peer.rb +25 -0
  43. data/lib/entity/seigniorage_allocation.rb +18 -0
  44. data/lib/entity/stored_contract_by_hash.rb +50 -0
  45. data/lib/entity/stored_contract_by_name.rb +50 -0
  46. data/lib/entity/stored_value.rb +57 -0
  47. data/lib/entity/stored_versioned_contract_by_hash.rb +61 -0
  48. data/lib/entity/stored_versioned_contract_by_name.rb +61 -0
  49. data/lib/entity/transfer.rb +65 -0
  50. data/lib/entity/validator_weight.rb +23 -0
  51. data/lib/entity/vesting_schedule.rb +22 -0
  52. data/lib/include.rb +18 -0
  53. data/lib/rpc/rpc.rb +227 -0
  54. data/lib/rpc/rpc_client.rb +233 -0
  55. data/lib/rpc/rpc_error.rb +79 -0
  56. data/lib/serialization/cl_type_serializer.rb +76 -0
  57. data/lib/serialization/cl_value_bytes_parsers.rb +498 -0
  58. data/lib/serialization/cl_value_serializer.rb +259 -0
  59. data/lib/serialization/deploy_approval_serializer.rb +15 -0
  60. data/lib/serialization/deploy_executable_serializer.rb +26 -0
  61. data/lib/serialization/deploy_header_serializer.rb +49 -0
  62. data/lib/serialization/deploy_named_arg_serializer.rb +19 -0
  63. data/lib/serialization/deploy_serializer.rb +268 -0
  64. data/lib/serialization/test.rb +431 -0
  65. data/lib/types/cl_account_hash.rb +24 -0
  66. data/lib/types/cl_account_hash_type.rb +22 -0
  67. data/lib/types/cl_any.rb +25 -0
  68. data/lib/types/cl_any_type.rb +22 -0
  69. data/lib/types/cl_bool.rb +32 -0
  70. data/lib/types/cl_bool_type.rb +35 -0
  71. data/lib/types/cl_byte_array.rb +25 -0
  72. data/lib/types/cl_byte_array_type.rb +27 -0
  73. data/lib/types/cl_i32.rb +26 -0
  74. data/lib/types/cl_i32_type.rb +26 -0
  75. data/lib/types/cl_i64.rb +26 -0
  76. data/lib/types/cl_i64_type.rb +27 -0
  77. data/lib/types/cl_key.rb +39 -0
  78. data/lib/types/cl_key_type.rb +27 -0
  79. data/lib/types/cl_list.rb +25 -0
  80. data/lib/types/cl_list_type.rb +26 -0
  81. data/lib/types/cl_map.rb +25 -0
  82. data/lib/types/cl_map_type.rb +26 -0
  83. data/lib/types/cl_option.rb +33 -0
  84. data/lib/types/cl_option_type.rb +52 -0
  85. data/lib/types/cl_public_key.rb +152 -0
  86. data/lib/types/cl_public_key_type.rb +26 -0
  87. data/lib/types/cl_result.rb +25 -0
  88. data/lib/types/cl_result_type.rb +26 -0
  89. data/lib/types/cl_string.rb +39 -0
  90. data/lib/types/cl_string_type.rb +32 -0
  91. data/lib/types/cl_tuple.rb +151 -0
  92. data/lib/types/cl_tuple_type.rb +108 -0
  93. data/lib/types/cl_type.rb +94 -0
  94. data/lib/types/cl_type_tag.rb +51 -0
  95. data/lib/types/cl_u128.rb +26 -0
  96. data/lib/types/cl_u128_type.rb +26 -0
  97. data/lib/types/cl_u256.rb +26 -0
  98. data/lib/types/cl_u256_type.rb +26 -0
  99. data/lib/types/cl_u32.rb +26 -0
  100. data/lib/types/cl_u32_type.rb +26 -0
  101. data/lib/types/cl_u512.rb +26 -0
  102. data/lib/types/cl_u512_type.rb +26 -0
  103. data/lib/types/cl_u64.rb +26 -0
  104. data/lib/types/cl_u64_type.rb +27 -0
  105. data/lib/types/cl_u8.rb +26 -0
  106. data/lib/types/cl_u8_type.rb +26 -0
  107. data/lib/types/cl_unit.rb +38 -0
  108. data/lib/types/cl_unit_type.rb +22 -0
  109. data/lib/types/cl_uref.rb +119 -0
  110. data/lib/types/cl_uref_type.rb +46 -0
  111. data/lib/types/cl_value.rb +10 -0
  112. data/lib/types/constants.rb +50 -0
  113. data/lib/types/error.rb +7 -0
  114. data/lib/utils/base_16.rb +18 -0
  115. data/lib/utils/byte_utils.rb +107 -0
  116. data/lib/utils/find_byte_parser_by_cl_type.rb +53 -0
  117. data/lib/utils/hash_utils.rb +19 -0
  118. data/lib/utils/hex_utils.rb +12 -0
  119. data/lib/utils/time_utils.rb +85 -0
  120. data/lib/utils/utils.rb +2 -0
  121. data/lib/version.rb +3 -0
  122. data/spec/a_spec.rb +697 -0
  123. data/spec/byte_utils_spec.rb +72 -0
  124. data/spec/cl_public_spec.rb +169 -0
  125. data/spec/cl_types_spec.rb +715 -0
  126. data/spec/cl_value_serializer_spec.rb +140 -0
  127. data/spec/client_spec.rb +25 -0
  128. data/spec/crypto_spec.rb +42 -0
  129. data/spec/deploy_approval_serializer_spec.rb +26 -0
  130. data/spec/deploy_executable_serializer_spec.rb +0 -0
  131. data/spec/deploy_header_serializer_spec.rb +21 -0
  132. data/spec/deploy_named_arg_serializer_spec.rb +49 -0
  133. data/spec/deploy_serializer_spec.rb +77 -0
  134. data/spec/deploy_serializer_test_spec.rb +225 -0
  135. data/spec/mainnet_spec.rb +452 -0
  136. data/spec/spec_helper.rb +100 -0
  137. data/spec/string_spec.rb +68 -0
  138. data/spec/testnet_spec.rb +498 -0
  139. data/spec/time_utils_spec.rb +87 -0
  140. metadata +162 -7
@@ -0,0 +1,233 @@
1
+ require 'jimson'
2
+ require 'json'
3
+ require 'rdoc/rdoc'
4
+ require "ipaddress"
5
+ require 'resolv'
6
+ require 'rest-client'
7
+ require 'active_support/core_ext/hash/keys'
8
+ require 'timeout'
9
+ require 'net/http'
10
+ require_relative './rpc_error.rb'
11
+ # Class for interacting with the network via RPC
12
+ module Casper
13
+ class RpcClient
14
+ attr_accessor :ip_address, :port, :url, :state_root_hash
15
+
16
+ # Constructor
17
+ # @param [String] ip_address
18
+ def initialize(ip_address)
19
+ @ip_address = ip_address
20
+ @url = "http://" + @ip_address + ":7777/rpc"
21
+ @state_root_hash = ""
22
+ @peer_array = []
23
+ @block_hash = ""
24
+ @deploy = {}
25
+ @node_status = {}
26
+ @block_transfers = []
27
+ @block_info = {}
28
+ @era_summary = {}
29
+ @balance_value = ""
30
+ @auction_state = {}
31
+
32
+ @rpc_error = Casper::RpcError::ErrorHandle.new
33
+ @err = @rpc_error.error_handling(@url)
34
+
35
+ end
36
+
37
+ def get_error
38
+ @err
39
+ end
40
+
41
+ # @return [Array<Hash>] peers array
42
+ def info_get_peers
43
+ begin
44
+ client = Jimson::Client.new(@url)
45
+ response = client.info_get_peers
46
+ @peer_array = response["peers"]
47
+ rescue
48
+ @rpc_error = Casper::RpcError::ErrorHandle.new
49
+ @error = @rpc_error.error_handling(@url)
50
+ end
51
+ end
52
+
53
+ # @return [String] state_root_hash value
54
+ def chain_get_StateRootHash(block_hash = "")
55
+ begin
56
+ status = Timeout::timeout(10) {
57
+ client = Jimson::Client.new(@url)
58
+ result = client.chain_get_state_root_hash
59
+ @state_root_hash = result["state_root_hash"]
60
+ }
61
+ rescue
62
+ @rpc_error = Casper::RpcError::ErrorHandle.new
63
+ @error = @rpc_error.error_handling(@url)
64
+ end
65
+ end
66
+
67
+ # Get information about a single deploy by hash.
68
+ # @param [String] deploy_hash
69
+ # @return [Hash] Deploy
70
+ def info_get_deploy(deploy_hash)
71
+ begin
72
+ status = Timeout::timeout(10) {
73
+ client = Jimson::Client.new(@url)
74
+ response = client.info_get_deploy({"deploy_hash"=> deploy_hash })
75
+ if (deploy_hash == "" || deploy_hash == nil)
76
+ Casper::RpcError::InvalidParameter.error
77
+ end
78
+ @deploy = response["deploy"]
79
+ # @deploy.keys.each do |key|
80
+ # @deploy[(key.to_sym rescue key) || key] = @deploy.delete(key)
81
+ # end
82
+ @deploy
83
+ }
84
+ rescue
85
+ Casper::RpcError::InvalidParameter.error
86
+ end
87
+ end
88
+
89
+
90
+ # Receive node status information
91
+ # @return node_status
92
+ def info_get_status
93
+ begin
94
+ status = Timeout::timeout(10) {
95
+ client = Jimson::Client.new(@url)
96
+ @node_status = client.info_get_status
97
+ }
98
+ rescue
99
+ @rpc_error = Casper::RpcError::ErrorHandle.new
100
+ @error = @rpc_error.error_handling(@url)
101
+ end
102
+ end
103
+
104
+ # @param [String] block_hash
105
+ # @return [Array<Hash>] block_transfers
106
+ def chain_get_block_transfers(block_hash = "")
107
+ begin
108
+ status = Timeout::timeout(5) {
109
+ client = Jimson::Client.new(@url)
110
+ response = client.chain_get_block_transfers({
111
+ "block_identifier" => {"Hash" => block_hash}
112
+ })
113
+ @block_transfers = response["transfers"]
114
+ @block_transfers
115
+ }
116
+ rescue
117
+ Casper::RpcError::InvalidParameter.error
118
+ end
119
+ end
120
+
121
+ # @param [String] block_hash
122
+ # @return [Hash] block_info
123
+ def chain_get_block(block_hash)
124
+ begin
125
+ state = Timeout::timeout(10) {
126
+ client = Jimson::Client.new(@url)
127
+ result = client.chain_get_block({"block_identifier" => {"Hash" => block_hash}})
128
+ @block_info = result["block"]
129
+ if (!@block_info.empty?() && @block_info["hash"] != block_hash)
130
+ raise("Returned block does not have a matching hash.")
131
+ else
132
+ @block_info
133
+ end
134
+ }
135
+ rescue
136
+ Casper::RpcError::InvalidParameter.error
137
+ end
138
+ end
139
+
140
+ # @param [String] block_hash
141
+ # @return [Hash] era_summary
142
+ def chain_get_eraInfo_by_SwitchBlock(block_hash)
143
+ begin
144
+ state = Timeout::timeout(10) {
145
+ client = Jimson::Client.new(@url)
146
+ response = client.chain_get_era_info_by_switch_block("block_identifier" => {"Hash" => block_hash})
147
+ @era_summary = response["era_summary"]
148
+
149
+ if @era_summary == nil
150
+ Casper::RpcError::InvalidParameter.error
151
+ else
152
+ @era_summary
153
+ end
154
+ }
155
+ rescue
156
+ Casper::RpcError::InvalidParameter.error
157
+ end
158
+ end
159
+
160
+ # @param [String] state_root_hash
161
+ # @param [String] key
162
+ # @param [Array] path
163
+ def state_get_item(state_root_hash, key, path)
164
+ begin
165
+ state = Timeout::timeout(20) {
166
+ client = Jimson::Client.new(@url)
167
+ response = client.state_get_item({
168
+ "state_root_hash" => state_root_hash,
169
+ "key" => key,
170
+ "path" => path
171
+ })
172
+ @stored_value = response["stored_value"]
173
+ @stored_value
174
+ }
175
+ rescue
176
+ Casper::RpcError::InvalidParameter.error
177
+ end
178
+ end
179
+
180
+ # @param [String] state_root_hash
181
+ # @param [String] item_key
182
+ # @param [String] uref
183
+ def state_get_dictionary_item(state_root_hash, item_key, uref)
184
+ begin
185
+ state = Timeout::timeout(10) {
186
+ client = Jimson::Client.new(@url)
187
+ response = client.state_get_dictionary_item({
188
+ "state_root_hash" => state_root_hash,
189
+ "dictionary_identifier" => {'URef' =>
190
+ {'seed_uref' => uref, 'dictionary_item_key' => item_key} }})
191
+ @stored_value = response["stored_value"]
192
+ @stored_value
193
+ }
194
+ rescue
195
+ Casper::RpcError::InvalidParameter.error
196
+ end
197
+ end
198
+
199
+ # @param [String] state_root_hash
200
+ # @param [String] balance_uref
201
+ def state_get_balance(state_root_hash, balance_uref)
202
+ begin
203
+ state = Timeout::timeout(5) {
204
+ client = Jimson::Client.new(@url)
205
+ response = client.state_get_balance({
206
+ "state_root_hash" => state_root_hash,
207
+ "purse_uref" => balance_uref
208
+ })
209
+ @balance_value = response["balance_value"]
210
+ @balance_value
211
+ }
212
+ rescue
213
+ Casper::RpcError::InvalidParameter.error
214
+ end
215
+ end
216
+
217
+ # Returns current auction system contract information.
218
+ # @return [Hash] auction_state
219
+ def state_get_AuctionInfo
220
+ begin
221
+ state = Timeout::timeout(50) {
222
+ client = Jimson::Client.new(@url)
223
+ response = client.state_get_auction_info
224
+ @auction_state = response['auction_state']
225
+ @auction_state
226
+ }
227
+ rescue
228
+ @rpc_error = Casper::RpcError::ErrorHandle.new
229
+ @error = @rpc_error.error_handling(@url)
230
+ end
231
+ end
232
+ end
233
+ end
@@ -0,0 +1,79 @@
1
+
2
+ module Casper
3
+ module RpcError
4
+ class ErrorHandle
5
+ # @param [Integer] code
6
+ # @param [String] message
7
+ # @param [String] data
8
+ def initialize(code = 0, message = "", data = "")
9
+ @code = code
10
+ @message = message
11
+ @data = data
12
+ end
13
+
14
+ # @return [String] err
15
+ def self.invalid_param
16
+ @code = -32602
17
+ @message = "Invalid params"
18
+ @err = "Server error #{@code}: #{@message}"
19
+ end
20
+
21
+ # @param [String] url
22
+ # @return [String]
23
+ def error_handling(url)
24
+ begin
25
+ response = RestClient.get(url)
26
+ parsed = JSON.parse(response)
27
+ # p parsed
28
+ rescue RestClient::ResourceNotFound => e
29
+ e.class.inspect
30
+ # "ResourceNotFound"
31
+ rescue Errno::ECONNREFUSED => e
32
+ e.class.inspect
33
+ # p e.class
34
+ # "Errno::ECONNREFUSED"
35
+ rescue SocketError => e
36
+ e.class.inspect
37
+ # "Socket Error"
38
+ rescue
39
+ "Timed out connecting to server"
40
+ end
41
+ end
42
+
43
+ # @return [String]
44
+ def invalid_address
45
+ "getaddrinfo: Name or service not known (SocketError)"
46
+ end
47
+
48
+ # @return [String]
49
+ def invalid_parameter
50
+ "Server error -32602: Invalid params"
51
+ end
52
+ end
53
+
54
+ class ServerError < StandardError
55
+
56
+ # @return [String]
57
+ def initialize(code, message)
58
+ super("Server error #{code}: #{message}")
59
+ end
60
+ end
61
+
62
+ class InvalidParameter
63
+
64
+ def initialize
65
+ end
66
+
67
+ # @return [String]
68
+ def self.error
69
+ "Server error -32602: Invalid params"
70
+ end
71
+
72
+ # @return [String]
73
+ def self.argument_error
74
+ "ArgumentError"
75
+ end
76
+ end
77
+
78
+ end
79
+ end
@@ -0,0 +1,76 @@
1
+ require_relative '../types/cl_bool_type.rb'
2
+ require_relative '../types/cl_bool.rb'
3
+ require_relative '../types/cl_i32_type.rb'
4
+ require_relative '../types/cl_i64_type.rb'
5
+ require_relative '../types/cl_u8_type.rb'
6
+ require_relative '../types/cl_u32_type.rb'
7
+ require_relative '../types/cl_u64_type.rb'
8
+ require_relative '../types/cl_u128_type.rb'
9
+ require_relative '../types/cl_u256_type.rb'
10
+ require_relative '../types/cl_u512_type.rb'
11
+ require_relative '../types/cl_unit_type.rb'
12
+ require_relative '../types/cl_string_type.rb'
13
+ require_relative '../types/cl_key_type.rb'
14
+ require_relative '../types/cl_option_type.rb'
15
+ require_relative '../types/cl_list_type.rb'
16
+ require_relative '../types/cl_byte_array_type.rb'
17
+ require_relative '../types/cl_result_type.rb'
18
+ require_relative '../types/cl_map_type.rb'
19
+ require_relative '../types/cl_tuple_type.rb'
20
+ require_relative '../types/cl_any_type.rb'
21
+ require_relative '../types/cl_public_key_type.rb'
22
+
23
+ class CLTypeSerizalizer
24
+
25
+ def self.serialize_cl_type(cl_type)
26
+ if cl_type.to_string == "Bool"
27
+ [0].pack("C*").unpack1("H*")
28
+ elsif cl_type.to_string == "I32"
29
+ [1].pack("C*").unpack1("H*")
30
+ elsif cl_type.to_string == "I64"
31
+ [2].pack("C*").unpack1("H*")
32
+ elsif cl_type.to_string == "U8"
33
+ [3].pack("C*").unpack1("H*")
34
+ elsif cl_type.to_string == "U32"
35
+ [4].pack("C*").unpack1("H*")
36
+ elsif cl_type.to_string == "U64"
37
+ [5].pack("C*").unpack1("H*")
38
+ elsif cl_type.to_string == "U128"
39
+ [6].pack("C*").unpack1("H*")
40
+ elsif cl_type.to_string == "U256"
41
+ [7].pack("C*").unpack1("H*")
42
+ elsif cl_type.to_string == "U512"
43
+ [8].pack("C*").unpack1("H*")
44
+ elsif cl_type.to_string == "Unit"
45
+ [9].pack("C*").unpack1("H*")
46
+ elsif cl_type.to_string == "String"
47
+ [10].pack("C*").unpack1("H*")
48
+ elsif cl_type.to_string == "Key"
49
+ [11].pack("C*").unpack1("H*")
50
+ elsif cl_type.to_string == "URef"
51
+ [12].pack("C*").unpack1("H*")
52
+ elsif cl_type.to_string == "Option"
53
+ [13].pack("C*").unpack1("H*") + serialize_cl_type(cl_type.get_inner_type)
54
+ elsif cl_type.to_string == "List"
55
+ [14].pack("C*").unpack1("H*")
56
+ elsif cl_type.to_string == "ByteArray"
57
+ [15].pack("C*").unpack1("H*")
58
+ elsif cl_type.to_string == "Result"
59
+ [16].pack("C*").unpack1("H*")
60
+ elsif cl_type.to_string == "Map"
61
+ [17].pack("C*").unpack1("H*")
62
+ elsif cl_type.to_string == "Tuple1"
63
+ [18].pack("C*").unpack1("H*") + cl_type.get_data[0].to_bytes
64
+ elsif cl_type.to_string == "Tuple2"
65
+ [19].pack("C*").unpack1("H*") + cl_type.get_data[0].to_bytes + cl_type.get_data[1].to_bytes
66
+ elsif cl_type.to_string == "Tuple3"
67
+ [20].pack("C*").unpack1("H*") + cl_type.get_data[0].to_bytes + cl_type.get_data[1].to_bytes + cl_type.get_data[2].to_bytes
68
+ elsif cl_type.to_string == "Any"
69
+ [21].pack("C*").unpack1("H*")
70
+ elsif cl_type.to_string == "PublicKey"
71
+ [22].pack("C*").unpack1("H*")
72
+ else
73
+ "Undefined"
74
+ end
75
+ end
76
+ end