Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Netherdrake/py-eos-api
Unofficial Wrapper for EOS API (eosd) for Python 3.6+
https://github.com/Netherdrake/py-eos-api
Last synced: about 2 months ago
JSON representation
Unofficial Wrapper for EOS API (eosd) for Python 3.6+
- Host: GitHub
- URL: https://github.com/Netherdrake/py-eos-api
- Owner: Netherdrake
- License: mit
- Created: 2017-09-15T07:44:07.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2018-05-18T14:34:48.000Z (over 6 years ago)
- Last Synced: 2024-08-01T08:07:51.695Z (4 months ago)
- Language: Python
- Homepage:
- Size: 22.5 KB
- Stars: 54
- Watchers: 13
- Forks: 21
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-eos-security - EOS Python - This is an unofficial API wrapper (EOS Smart Contract Development / Programming tools)
- awesome-eos - eosapi - EOS api wrapper for Python 3.6+ (Language Support / Python)
- awesome-EOS - eosapi - EOS API wrapper for Python 3.6+. (Language Support / Python)
- awesome_eos - eosapi - EOS api wrapper for Python 3.6+ (Language Support / Python)
README
## Python EOS Api Client
This is an unofficial API wrapper by [@furion](https://steemit.com/@furion)## Installation
```
pip install -U git+https://github.com/Netherdrake/py-eos-api
```## Usage
```python
>>> from eosapi import Client
>>> c = Client(nodes=['http://localhost:8888'])>>> c.get_info()
{'head_block_id': '0000652e92c1f73e14503383ee18c28901dd301ff5be0b94c77d846d799d5050',
'head_block_num': 25902,
'head_block_producer': 'initi',
'head_block_time': '2017-09-16T04:25:18',
'last_irreversible_block_num': 25884,
'participation_rate': '1.00000000000000000',
'recent_slots': '1111111111111111111111111111111111111111111111111111111111111111'}>>> c.get_account?
Signature: c.get_account(name) -> dict
Docstring: Fetch a blockchain account
File: ~/GitHub/EOS/py-eos-api/eosapi/api.py
Type: method>>> c.get_account('inita')
{'eos_balance': '1000000.0000 EOS',
'last_unstaking_time': '1969-12-31T23:59:59',
'name': 'inita',
'permissions': [{'name': 'active',
'parent': 'owner',
'required_auth': {'accounts': [],
'keys': [{'key': 'EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV',
'weight': 1}],
'threshold': 1}},
{'name': 'owner',
'parent': 'owner',
'required_auth': {'accounts': [],
'keys': [{'key': 'EOS6MRyAjQq8ud7hVNYcfnVPJqcVpscN5So8BhtHuGYqET5GDW5CV',
'weight': 1}],
'threshold': 1}}],
'staked_balance': '0.0000 EOS',
'unstaking_balance': '0.0000 EOS'}
```You can also use a lower level `HttpClient` directly:
```python
from eosapi import HttpClienth = HttpClient(["http://localhost:8888"])
print(h.exec('chain', 'get_block', '{"block_num_or_id": 5}'))
print(h.exec('chain', 'get_block', {"block_num_or_id": 5}))
print(h.exec('chain', 'get_info'))
```You can also stream raw blocks (polling indefinitely):
```python
from eosapi import Client
c = Client()for block in c.stream_blocks(start_block=100, mode='head'):
print(block)
```### TODO
- add support for type hints _(Union[NativeType, PythonType])_
- split api into submodules to avoid potential collisions
- apigen: load from json spec files once they are finalized### License
MIT