ethereum 0.3.8 → 0.3.47
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +3 -29
- data/lib/ethereum.rb +0 -3
- data/lib/ethereum/contract.rb +32 -35
- data/lib/ethereum/deployment.rb +2 -2
- data/lib/ethereum/formatter.rb +2 -2
- data/lib/ethereum/ipc_client.rb +12 -1
- data/lib/ethereum/transaction.rb +3 -5
- data/lib/ethereum/version.rb +1 -1
- metadata +2 -4
- data/lib/ethereum/client.rb +0 -18
- data/lib/ethereum/http_client.rb +0 -40
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 619380b40d2004b955dc3053487b95bab5d7ad86
|
4
|
+
data.tar.gz: 97ffe5537e9127401fae43449c22caaf0c7340bc
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: ca884f158d3fd4463d1b066bae6fb208988d395a6c89378bfd11153c6418bfe62805927e69d3e6c799b9604a216e3aee08a60e67ee53723c8bdd299f995e7024
|
7
|
+
data.tar.gz: 983f6e6cb8b8f16c0e9839435aa4aa82ac09943cee4e9c5cc7ae67ce4b3b1a8e87fb23e585bd5b99492190347246dec2291fe696b0e5ef112518ba428bde7bbb
|
data/README.md
CHANGED
@@ -6,7 +6,6 @@ A simple library for Ethereum.
|
|
6
6
|
|
7
7
|
* Pure Ruby implementation
|
8
8
|
* IPC Client with batch calls support
|
9
|
-
* HTTP Client with batch calls support
|
10
9
|
* Compile and deploy Solidity contracts
|
11
10
|
* Expose deployed contracts as Ruby classes
|
12
11
|
* Test solidity contracts with a Ruby testing framework of your choice
|
@@ -62,34 +61,11 @@ simple_name_registry_instance.deploy_and_wait
|
|
62
61
|
|
63
62
|
### Transacting and Calling Solidity Functions
|
64
63
|
|
65
|
-
Solidity functions are exposed
|
66
|
-
|
67
|
-
```
|
68
|
-
transact_[function_name](params)
|
69
|
-
transact_and_wait_[function_name](params)
|
70
|
-
call_[function_name](params)
|
71
|
-
```
|
72
|
-
|
73
|
-
**Example Contract in Solidity**
|
74
|
-
```
|
75
|
-
contract SimpleNameRegistry {
|
76
|
-
|
77
|
-
mapping (address => bool) public myMapping;
|
78
|
-
|
79
|
-
function register(address _a, bytes32 _b) {
|
80
|
-
}
|
81
|
-
|
82
|
-
function getSomeValue(address _x) public constant returns(bool b, address b) {
|
83
|
-
}
|
84
|
-
|
85
|
-
}
|
86
|
-
```
|
64
|
+
Solidity functions are exposed as transact_<underscore_function_name>(params) (or transact_and_wait_<underscore_function_name>(params)) and call_<underscore_function_name>(params) e.g.:
|
87
65
|
|
88
66
|
```ruby
|
89
67
|
simple_name_registry_instance.transact_and_wait_register("0x5b6cb65d40b0e27fab87a2180abcab22174a2d45", "minter.contract.dgx")
|
90
68
|
simple_name_registry_instance.transact_register("0x385acafdb80b71ae001f1dbd0d65e62ec2fff055", "anthony@eufemio.dgx")
|
91
|
-
simple_name_registry_instance.call_get_some_value("0x385acafdb80b71ae001f1dbd0d65e62ec2fff055")
|
92
|
-
simple_name_registry_instance.call_my_mapping("0x385acafdb80b71ae001f1dbd0d65e62ec2fff055")
|
93
69
|
```
|
94
70
|
|
95
71
|
### Run contracts using a different address
|
@@ -106,12 +82,10 @@ simple_name_registry_instance.at("0x734533083b5fc0cd14b7cb8c8eb6ed0c9bd184d3")
|
|
106
82
|
|
107
83
|
## Roadmap
|
108
84
|
|
85
|
+
* Add JSON RPC Client support
|
109
86
|
* Add Windows IPC Client (named pipes)
|
110
|
-
* Add support for creating and sending of raw transactions
|
111
|
-
* Offline account creation
|
112
87
|
* Solidity constant function output should be properly formatted according to the ouput data type
|
113
|
-
* Unit testing and contract testing examples
|
114
|
-
* ContractTransaction class
|
88
|
+
* Unit testing and contract testing examples
|
115
89
|
* Add more examples
|
116
90
|
* API documentation
|
117
91
|
|
data/lib/ethereum.rb
CHANGED
@@ -1,12 +1,9 @@
|
|
1
1
|
require "ethereum/version"
|
2
2
|
require 'active_support'
|
3
3
|
require 'active_support/core_ext'
|
4
|
-
require 'sha3-pure-ruby'
|
5
4
|
|
6
5
|
module Ethereum
|
7
|
-
require 'ethereum/client'
|
8
6
|
require 'ethereum/ipc_client'
|
9
|
-
require 'ethereum/http_client'
|
10
7
|
require 'ethereum/initializer'
|
11
8
|
require 'ethereum/contract'
|
12
9
|
require 'ethereum/function'
|
data/lib/ethereum/contract.rb
CHANGED
@@ -71,44 +71,41 @@ module Ethereum
|
|
71
71
|
end
|
72
72
|
|
73
73
|
functions.each do |fun|
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
74
|
+
if fun.constant
|
75
|
+
define_method "call_#{fun.name.underscore}".to_sym do |*args|
|
76
|
+
formatter = Ethereum::Formatter.new
|
77
|
+
arg_types = fun.inputs.collect(&:type)
|
78
|
+
#out_types = fun.outputs.collect(&:type)
|
79
|
+
connection = self.connection
|
80
|
+
return {result: :error, message: "missing parameters for #{fun.function_string}" } if arg_types.length != args.length
|
81
|
+
payload = []
|
82
|
+
payload << fun.signature
|
83
|
+
arg_types.zip(args).each do |arg|
|
84
|
+
payload << formatter.to_payload(arg)
|
85
|
+
end
|
86
|
+
return {result: connection.call({to: self.address, from: self.sender, data: payload.join()})["result"].gsub(/^0x/,'').scan(/.{64}/)}
|
85
87
|
end
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
88
|
+
else
|
89
|
+
define_method "transact_#{fun.name.underscore}".to_sym do |*args|
|
90
|
+
formatter = Ethereum::Formatter.new
|
91
|
+
arg_types = fun.inputs.collect(&:type)
|
92
|
+
connection = self.connection
|
93
|
+
return {result: :error, message: "missing parameters for #{fun.function_string}" } if arg_types.length != args.length
|
94
|
+
payload = []
|
95
|
+
payload << fun.signature
|
96
|
+
arg_types.zip(args).each do |arg|
|
97
|
+
payload << formatter.to_payload(arg)
|
98
|
+
end
|
99
|
+
txid = connection.send_transaction({to: self.address, from: self.sender, data: payload.join(), gas: self.gas, gasPrice: self.gas_price})["result"]
|
100
|
+
return Ethereum::Transaction.new(txid, self.connection)
|
101
|
+
end
|
102
|
+
define_method "transact_and_wait_#{fun.name.underscore}".to_sym do |*args|
|
103
|
+
function_name = "transact_#{fun.name.underscore}".to_sym
|
104
|
+
tx = self.send(function_name, *args)
|
105
|
+
tx.wait_for_miner
|
106
|
+
return tx
|
100
107
|
end
|
101
|
-
txid = connection.send_transaction({to: self.address, from: self.sender, data: payload.join(), gas: self.gas, gasPrice: self.gas_price})["result"]
|
102
|
-
return Ethereum::Transaction.new(txid, self.connection, payload.join(), args)
|
103
|
-
end
|
104
|
-
|
105
|
-
define_method "transact_and_wait_#{fun.name.underscore}".to_sym do |*args|
|
106
|
-
function_name = "transact_#{fun.name.underscore}".to_sym
|
107
|
-
tx = self.send(function_name, *args)
|
108
|
-
tx.wait_for_miner
|
109
|
-
return tx
|
110
108
|
end
|
111
|
-
|
112
109
|
end
|
113
110
|
end
|
114
111
|
Object.const_set(class_name, class_methods)
|
data/lib/ethereum/deployment.rb
CHANGED
@@ -31,10 +31,10 @@ module Ethereum
|
|
31
31
|
@valid_deployment = @connection.get_code(@contract_address)["result"] != "0x"
|
32
32
|
end
|
33
33
|
|
34
|
-
def wait_for_deployment(timeout =
|
34
|
+
def wait_for_deployment(timeout = 60.seconds)
|
35
35
|
start_time = Time.now
|
36
36
|
while self.deployed? == false
|
37
|
-
raise
|
37
|
+
raise Timeout::Error if ((Time.now - start_time) > timeout)
|
38
38
|
sleep 5
|
39
39
|
return true if self.deployed?
|
40
40
|
end
|
data/lib/ethereum/formatter.rb
CHANGED
@@ -54,11 +54,11 @@ module Ethereum
|
|
54
54
|
end
|
55
55
|
|
56
56
|
def uint_to_payload(uint)
|
57
|
-
self.to_twos_complement(uint)
|
57
|
+
self.to_twos_complement(uint)
|
58
58
|
end
|
59
59
|
|
60
60
|
def int_to_payload(int)
|
61
|
-
self.to_twos_complement(uint)
|
61
|
+
self.to_twos_complement(uint)
|
62
62
|
end
|
63
63
|
|
64
64
|
def bytes_to_payload(bytes)
|
data/lib/ethereum/ipc_client.rb
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
require 'socket'
|
2
2
|
module Ethereum
|
3
|
-
class IpcClient
|
3
|
+
class IpcClient
|
4
4
|
attr_accessor :command, :id, :ipcpath, :batch, :converted_transactions
|
5
5
|
|
6
6
|
def initialize(ipcpath = "#{ENV['HOME']}/.ethereum/geth.ipc")
|
@@ -9,6 +9,13 @@ module Ethereum
|
|
9
9
|
@batch = []
|
10
10
|
end
|
11
11
|
|
12
|
+
def get_id
|
13
|
+
@id = @id + 1
|
14
|
+
return @id
|
15
|
+
end
|
16
|
+
|
17
|
+
RPC_COMMANDS = %w(eth_accounts eth_blockNumber eth_getBalance eth_protocolVersion eth_coinbase eth_mining eth_gasPrice eth_getStorage eth_storageAt eth_getStorageAt eth_getTransactionCount eth_getBlockTransactionCountByHash eth_getBlockTransactionCountByNumber eth_getUncleCountByBlockHash eth_getUncleCountByBlockNumber eth_getData eth_getCode eth_sign eth_sendRawTransaction eth_sendTransaction eth_transact eth_estimateGas eth_call eth_flush eth_getBlockByHash eth_getBlockByNumber eth_getTransactionByHash eth_getTransactionByBlockNumberAndIndex eth_getTransactionByBlockHashAndIndex eth_getUncleByBlockHashAndIndex eth_getUncleByBlockNumberAndIndex eth_getCompilers eth_compileSolidity eth_newFilter eth_newBlockFilter eth_newPendingTransactionFilter eth_uninstallFilter eth_getFilterChanges eth_getFilterLogs eth_getLogs eth_hashrate eth_getWork eth_submitWork eth_resend eth_pendingTransactions eth_getTransactionReceipt)
|
18
|
+
|
12
19
|
RPC_COMMANDS.each do |rpc_command|
|
13
20
|
method_name = "#{rpc_command.split("_")[1].underscore}"
|
14
21
|
define_method method_name do |*args|
|
@@ -45,6 +52,10 @@ module Ethereum
|
|
45
52
|
return collection
|
46
53
|
end
|
47
54
|
|
55
|
+
def clear_batch
|
56
|
+
@batch = []
|
57
|
+
end
|
58
|
+
|
48
59
|
end
|
49
60
|
end
|
50
61
|
|
data/lib/ethereum/transaction.rb
CHANGED
@@ -1,14 +1,12 @@
|
|
1
1
|
module Ethereum
|
2
2
|
|
3
3
|
class Transaction
|
4
|
-
attr_accessor :id, :mined, :connection
|
4
|
+
attr_accessor :id, :mined, :connection
|
5
5
|
|
6
|
-
def initialize(id, connection
|
6
|
+
def initialize(id, connection)
|
7
7
|
@mined = false
|
8
8
|
@connection = connection
|
9
9
|
@id = id
|
10
|
-
@input = data
|
11
|
-
@input_parameters = input_parameters
|
12
10
|
end
|
13
11
|
|
14
12
|
def mined?
|
@@ -16,7 +14,7 @@ module Ethereum
|
|
16
14
|
@mined = @connection.get_transaction_by_hash(@id)["result"]["blockNumber"].present?
|
17
15
|
end
|
18
16
|
|
19
|
-
def wait_for_miner(timeout =
|
17
|
+
def wait_for_miner(timeout = 60.seconds)
|
20
18
|
start_time = Time.now
|
21
19
|
while self.mined? == false
|
22
20
|
raise Timeout::Error if ((Time.now - start_time) > timeout)
|
data/lib/ethereum/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ethereum
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.3.
|
4
|
+
version: 0.3.47
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- DigixGlobal Pte Ltd (https://dgx.io)
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2015-10-
|
11
|
+
date: 2015-10-08 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -116,14 +116,12 @@ files:
|
|
116
116
|
- bin/setup
|
117
117
|
- ethereum.gemspec
|
118
118
|
- lib/ethereum.rb
|
119
|
-
- lib/ethereum/client.rb
|
120
119
|
- lib/ethereum/contract.rb
|
121
120
|
- lib/ethereum/deployment.rb
|
122
121
|
- lib/ethereum/formatter.rb
|
123
122
|
- lib/ethereum/function.rb
|
124
123
|
- lib/ethereum/function_input.rb
|
125
124
|
- lib/ethereum/function_output.rb
|
126
|
-
- lib/ethereum/http_client.rb
|
127
125
|
- lib/ethereum/initializer.rb
|
128
126
|
- lib/ethereum/ipc_client.rb
|
129
127
|
- lib/ethereum/transaction.rb
|
data/lib/ethereum/client.rb
DELETED
@@ -1,18 +0,0 @@
|
|
1
|
-
module Ethereum
|
2
|
-
class Client
|
3
|
-
|
4
|
-
RPC_COMMANDS = %w(eth_accounts eth_blockNumber eth_getBalance eth_protocolVersion eth_coinbase eth_mining eth_gasPrice eth_getStorage eth_storageAt eth_getStorageAt eth_getTransactionCount eth_getBlockTransactionCountByHash eth_getBlockTransactionCountByNumber eth_getUncleCountByBlockHash eth_getUncleCountByBlockNumber eth_getData eth_getCode eth_sign eth_sendRawTransaction eth_sendTransaction eth_transact eth_estimateGas eth_call eth_flush eth_getBlockByHash eth_getBlockByNumber eth_getTransactionByHash eth_getTransactionByBlockNumberAndIndex eth_getTransactionByBlockHashAndIndex eth_getUncleByBlockHashAndIndex eth_getUncleByBlockNumberAndIndex eth_getCompilers eth_compileSolidity eth_newFilter eth_newBlockFilter eth_newPendingTransactionFilter eth_uninstallFilter eth_getFilterChanges eth_getFilterLogs eth_getLogs eth_hashrate eth_getWork eth_submitWork eth_resend eth_pendingTransactions eth_getTransactionReceipt)
|
5
|
-
|
6
|
-
def get_id
|
7
|
-
@id = @id + 1
|
8
|
-
return @id
|
9
|
-
end
|
10
|
-
|
11
|
-
def clear_batch
|
12
|
-
@batch = []
|
13
|
-
end
|
14
|
-
|
15
|
-
end
|
16
|
-
|
17
|
-
end
|
18
|
-
|
data/lib/ethereum/http_client.rb
DELETED
@@ -1,40 +0,0 @@
|
|
1
|
-
require 'pry'
|
2
|
-
module Ethereum
|
3
|
-
class HttpClient < Client
|
4
|
-
attr_accessor :command, :id, :host, :port, :batch, :converted_transactions, :uri
|
5
|
-
|
6
|
-
def initialize(host, port)
|
7
|
-
@host = host
|
8
|
-
@port = port
|
9
|
-
@id = 1
|
10
|
-
@uri = URI("http://#{@host}:#{@port}")
|
11
|
-
@batch = []
|
12
|
-
end
|
13
|
-
|
14
|
-
RPC_COMMANDS.each do |rpc_command|
|
15
|
-
method_name = "#{rpc_command.split("_")[1].underscore}"
|
16
|
-
define_method method_name do |*args|
|
17
|
-
command = rpc_command
|
18
|
-
payload = {jsonrpc: "2.0", method: command, params: args, id: get_id}
|
19
|
-
http = Net::HTTP.new(@host, @port)
|
20
|
-
header = {'Content-Type' => 'application/json'}
|
21
|
-
request = Net::HTTP::Post.new(uri, header)
|
22
|
-
request.body = payload.to_json
|
23
|
-
response = http.request(request)
|
24
|
-
return JSON.parse(response.body)
|
25
|
-
end
|
26
|
-
|
27
|
-
define_method "#{method_name}_batch" do |*args|
|
28
|
-
command = rpc_command
|
29
|
-
payload = {jsonrpc: "2.0", method: command, params: args, id: get_id}
|
30
|
-
@batch << payload.to_json
|
31
|
-
end
|
32
|
-
end
|
33
|
-
|
34
|
-
def send_batch
|
35
|
-
|
36
|
-
end
|
37
|
-
|
38
|
-
end
|
39
|
-
|
40
|
-
end
|