Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/DeV1doR/ethereumd-proxy
Proxy client-server for Ethereum node using bitcoin JSON-RPC interface.
https://github.com/DeV1doR/ethereumd-proxy
api asyncio bitcoin bitcoin-core bitcoind ethereum ethereumd protocol proxy python sanic
Last synced: 3 months ago
JSON representation
Proxy client-server for Ethereum node using bitcoin JSON-RPC interface.
- Host: GitHub
- URL: https://github.com/DeV1doR/ethereumd-proxy
- Owner: m-bo-one
- License: mit
- Created: 2017-07-14T15:03:52.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2022-08-06T05:21:52.000Z (over 2 years ago)
- Last Synced: 2024-08-18T12:05:16.382Z (3 months ago)
- Topics: api, asyncio, bitcoin, bitcoin-core, bitcoind, ethereum, ethereumd, protocol, proxy, python, sanic
- Language: Python
- Homepage:
- Size: 81.1 KB
- Stars: 21
- Watchers: 2
- Forks: 7
- Open Issues: 10
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGES.rst
- License: LICENSE
Awesome Lists containing this project
- awesome-sanic - ethereumd-proxy
README
|pypi| |coverage| |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
.. code:: bash
$ 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:
.. code:: bash
$ ethereum-cli -help
To start proxy server use:
.. code:: bash
$ ethereum-cli -datadir= -daemon
To stop server:
.. code:: bash
$ ethereum-cli -datadir= stop
Also can be used as python client connector:
.. code:: python
import asyncio
import ethereumdloop = 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
-----------------------.. code:: bash
#
# 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.
.. |pypi| image:: https://badge.fury.io/py/ethereumd-proxy.svg
:target: https://badge.fury.io/py/ethereumd-proxy
:alt: Latest version released on PyPi.. |coverage| image:: https://codecov.io/gh/DeV1doR/ethereumd-proxy/branch/master/graph/badge.svg
:target: https://codecov.io/gh/DeV1doR/ethereumd-proxy
:alt: Test coverage.. |license| image:: https://img.shields.io/badge/license-MIT-blue.svg
:target: https://opensource.org/licenses/MIT
:alt: MIT License