Skip to main content

Proxy client-server for Ethereum node using JSON-RPC interface.

Project description

Release Test coverage MIT License

ethereumd-proxy

Proxy client-server for Ethereum node using JSON-RPC interface.

Why?

Mostly popular cryptocurrencies usually are forks of Bitcoin and all of them support Bitcoin protocol for communication with their full nodes. Ethereum go hard by own way and made own API for that. This library is a proxy to Ethereum node which implement many API methods like in bitcoind. Also it have signals like blocknotify and walletnotify. All these features are implemented by ethereumd-proxy using polling and other techniques behind the scene.

Installation

Python 3.5+ required.

First you need Geth/Parity or any other ethereum node (for listening). Tested on Geth 1.6.7 and used in production.

Installation

$ pip install ethereumd-proxy

Usage

It is the same as bitcoin-cli. Except it is not a node runner, just simple proxy for listening actual node.

Available command list:

$ ethereum-cli -help

To start proxy server use:

$ ethereum-cli -datadir=<path_to_your_dir_with_node_and_ethereum.conf> -daemon

To stop server:

$ ethereum-cli -datadir=<path_to_your_dir_with_node_and_ethereum.conf> stop

Also can be used as python client connector:

import asyncio
import ethereumd

loop = asyncio.get_event_loop()

async def go():
    client = await ethereumd.create_ethereumd_proxy(
        'http://localhost:8545', loop=loop)

    val = await client.validateaddress('0x6cace0528324a8afc2b157ceba3cdd2a27c4e21f')
    print(val)  # will print {'isvalid': True, 'address': '0x6cace0528324a8afc2b157ceba3cdd2a27c4e21f', 'scriptPubKey': 'hex', 'ismine': False, 'iswatchonly': False, 'isscript': False, 'pubkey': '0x6cace0528324a8afc2b157ceba3cdd2a27c4e21f', 'iscompressed': False, 'timestamp': None}

    address = await client.getnewaddress(passphrase='admin')
    print(address)  # will print address like '0x137dd92be1d986eb3af023d0fb6fa8436c3ee5f8'

loop.run_until_complete(go())

Implemented JSON-RPC methods

Util

Wallet

Blockchain

validateaddress

getbalance

getblockhash

estimatefee

settxfee

getdifficulty

listaccounts

getblockcount

gettransaction

getbestblockhash

sendfrom

getblock

sendtoaddress

walletlock

walletpassphrase

getnewaddress

Planned add more methods as soon as possible. Read help of some method first before use!

Sample of ethereum.conf

#
# ETHEREUMD-PROXY options (for controlling a running proxy process)
#

# Local server address for ethereumd-proxy RPC:
#ethpconnect=127.0.0.1

# Local server port for ethereumd-proxy RPC:
#ethpport=9500

#
# JSON-RPC options (for controlling a running ethereum process)
#

# You can use go-ethereum to send commands to ethereum
# running on another host using this option:
#rpcconnect=127.0.0.1

# Listen for RPC connections on this TCP port:
#rpcport=8545

# Listen for RPC connections on this unix/ipc socket:
#ipcconnect=~/.ethereum/geth/geth.ipc

#
# Signals options (for controlling a script management process)
#

# Execute command when a wallet transaction changes (%s in cmd is replaced by TxID)
#walletnotify=
# Execute command when the best block changes (%s in cmd is replaced by block hash)
#blocknotify=
# Execute command when a relevant alert is received (%s in cmd is replaced by message)
# TODO: add notification of long fork
#alertnotify=

Copy it to your datadir folder or use direct path to it.

TODO

  • Add more RPC methods;

  • Track orphaned blocks;

Changes

0.3.0 (2017-10-01)

  • Integrated aioethereum library;

  • Fixed not worked tests;

  • Add new tests;

0.2.0 (2017-08-31)

  • Added new RPC methods:

    • getblockhash;

    • validateaddress;

    • estimatefee;

    • listsinceblock;

    • walletpassphrase;

    • walletlock;

    • getnewaddress;

    • sendfrom;

  • Added some methods optimizations;

0.1.2 (2017-08-09)

  • Increased testcov to 77%;

  • Added more tests for methods;

  • Fix error with alernotify;

0.1.1 (2017-07-31)

  • Added tests and codecov;

0.1 (2017-07-25)

  • Added cli for proxy RPC server;

  • Some bug fixes in API;

  • Added new RPC methods:

    • getbalance;

    • settxfee;

    • listaccounts;

    • gettransaction;

    • getdifficulty;

    • getblockcount;

    • getbestblockhash;

    • getblock;

    • sendtoaddress;

0.1a (2017-07-22)

  • Initial release

  • Added RPC methods:

    • gettransaction;

    • getblock;

    • listaccounts;

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ethereumd-proxy-0.3.0.tar.gz (132.5 kB view details)

Uploaded Source

Built Distribution

ethereumd_proxy-0.3.0-py3-none-any.whl (141.1 kB view details)

Uploaded Python 3

File details

Details for the file ethereumd-proxy-0.3.0.tar.gz.

File metadata

File hashes

Hashes for ethereumd-proxy-0.3.0.tar.gz
Algorithm Hash digest
SHA256 0e2d85a8ef1ecb67f9e87cb387f5ccd0a8ddbcfad716496770c8c66d01f77c38
MD5 15e6db58cf2668a16a22ba7628dc1f55
BLAKE2b-256 87e4c23b568b2dae5923a1fb3a6d0536d4770630013fef9b79fa55bfd47488d9

See more details on using hashes here.

File details

Details for the file ethereumd_proxy-0.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for ethereumd_proxy-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2aa1f289cdf9b21298456d7374462aa110d17267be4cb685a3566765c3459af2
MD5 eda1b585eaac7a8fa7181225228f6eac
BLAKE2b-256 3d9818eb4fa433da85e77f9939ef70df16c10d81498fc81449fab4ca521fc7fa

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page