-
Notifications
You must be signed in to change notification settings - Fork 13
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
cd8bdad
commit f45c61e
Showing
2 changed files
with
114 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,114 @@ | ||
# eth-client | ||
A Golang Client Library for Communicating with Ethereum RPC Servers | ||
eth-client | ||
========== | ||
|
||
[data:image/s3,"s3://crabby-images/21040/210400275b8b3d08cb0fdcf303d575598bd5fec2" alt="Travis"](https://travis-ci.org/getamis/eth-client) | ||
[data:image/s3,"s3://crabby-images/569f5/569f50cf6a17b83820935bf613fc0f4cc23a448c" alt="License: LGPL v3"](https://www.gnu.org/licenses/lgpl-3.0) | ||
[data:image/s3,"s3://crabby-images/1b572/1b572c4bc03e517710beca791f05a6625d113ebc" alt="Go Report Card"](https://goreportcard.com/report/github.com/getamis/eth-client) | ||
|
||
A Golang client library to communicate with Ethereum RPC server. | ||
* Implements most of JSON-RPC methods and several client-specific methods. | ||
* Provides a high-level interface to **propose/get validators** on Istanbul blockchain. | ||
* Provides a high-level interface to **create private contracts** on Quorum blockchain. | ||
|
||
Usage | ||
----- | ||
```golang | ||
package main | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
|
||
"github.com/getamis/eth-client/client" | ||
) | ||
|
||
func main() { | ||
url := "http://127.0.0.1:8545" | ||
client, err := client.Dial(url) | ||
if err != nil { | ||
fmt.Println("Failed to dial, url: ", url, ", err: ", err) | ||
return | ||
} | ||
|
||
err = client.StartMining(context.Background()) | ||
if err != nil { | ||
fmt.Println("Failed to start mining, err: ", err) | ||
return | ||
} | ||
fmt.Println("start mining") | ||
} | ||
|
||
``` | ||
|
||
Implemented JSON-RPC methods | ||
---------------------------- | ||
|
||
* admin_addPeer | ||
* admin_adminPeers | ||
* admin_nodeInfo | ||
* eth_blockNumber | ||
* eth_sendRawTransaction | ||
* eth_getBlockByHash | ||
* eth_getBlockByNumber | ||
* eth_getBlockByHash | ||
* eth_getBlockByNumber | ||
* eth_getTransactionByHash | ||
* eth_getBlockTransactionCountByHash | ||
* eth_getTransactionByBlockHashAndIndex | ||
* eth_getTransactionReceipt | ||
* eth_syncing | ||
* eth_getBalance | ||
* eth_getStorageAt | ||
* eth_getCode | ||
* eth_getBlockTransactionCountByNumber | ||
* eth_call | ||
* eth_gasPrice | ||
* eth_estimateGas | ||
* eth_sendRawTransaction | ||
* miner_startMining | ||
* miner_stopMining | ||
* net_version | ||
* logs | ||
* newHeads | ||
* eth_getLogs | ||
|
||
### Istanbul-only JSON-RPC methods | ||
To use these methods, make sure that | ||
* Server is running on [Istanbul consensus](https://github.com/ethereum/EIPs/issues/650). | ||
* Connect to server through `istanbul.Dial` function (not the original [Geth client](https://github.com/ethereum/go-ethereum/tree/master/ethclient)). | ||
|
||
Methods: | ||
|
||
* istanbul_getValidators | ||
* istanbul_propose | ||
|
||
### Quorum-only JSON-RPC methods | ||
|
||
To use these methods, make sure that | ||
* Server is running on [Quorum blockchain](https://github.com/jpmorganchase/quorum/wiki) | ||
* Connect to server through `quorum.Dial` function (not the original [Geth client](https://github.com/ethereum/go-ethereum/tree/master/ethclient)). | ||
|
||
Methods: | ||
|
||
* quorum_privateContract | ||
* quorum_contract | ||
|
||
Contributing | ||
------------ | ||
|
||
Feel free to contribute to this repository. | ||
|
||
1. Fork it! | ||
2. Create your feature branch: git checkout -b my-new-feature | ||
3. Commit your changes: git commit -am 'Add some feature' | ||
4. Push to the branch: git push origin my-new-feature | ||
5. Submit a pull request | ||
|
||
Reference | ||
--------- | ||
|
||
* https://github.com/ethereum/go-ethereum | ||
* https://github.com/ethereum/wiki/wiki/JSON-RPC | ||
* https://github.com/ethereum/EIPs/issues/650 | ||
* https://github.com/jpmorganchase/quorum | ||
* https://github.com/getamis/istanbul-tools |
Binary file not shown.