Skip to main content

Tools for exporting IoTeX blockchain data to JSON

Project description

IoTeX ETL CLI

Build Status Telegram

IoTeX ETL CLI lets you convert IoTeX data into JSON newline-delimited format.

Full documentation available here.

Quickstart

Install IoTeX ETL CLI:

pip3 install iotex-etl

Export blocks, actions and logs (Schema, Reference):

> iotexetl export_blocks --start-block 1 --end-block 500000 \
--output-dir output --provider-uri grpcs://api.mainnet.iotex.one:443

Stream blocks, actions and logs to console (Reference):

> pip3 install iotex-etl[streaming]
> iotexetl stream --start-block 500000 -e block,action,log --log-file log.txt \
--provider-uri grpcs://api.mainnet.iotex.one:443

Find other commands here.

For the latest version, check out the repo and call

> pip3 install -e . 
> python3 iotexetl.py

Useful Links

Running Tests

> pip3 install -e .[dev,streaming]
> export IOTEXETL_PROVIDER_URI=grpcs://api.mainnet.iotex.one:443
> pytest -vv

Running Tox Tests

> pip3 install tox
> tox

Running in Docker

  1. Install Docker https://docs.docker.com/install/

  2. Build a docker image

     > docker build -t iotex-etl:latest .
     > docker image ls
    
  3. Run a container out of the image

     > docker run -v $HOME/output:/iotex-etl/output iotex-etl:latest export_blocks -s 1 -e 5499999 -b 1000 -o out
    
  4. Run streaming to console or Pub/Sub

     > docker build -t iotex-etl:latest -f Dockerfile .
     > echo "Stream to console"
     > docker run iotex-etl:latest stream --start-block 500000 --log-file log.txt
     > echo "Stream to Pub/Sub"
     > docker run -v /path_to_credentials_file/:/iotex-etl/ --env GOOGLE_APPLICATION_CREDENTIALS=/iotex-etl/credentials_file.json iotex-etl:latest stream --start-block 500000 --output projects/<your-project>/topics/mainnet
    

Generating iotex types and api code

  1. Clone iotex-proto git repository https://github.com/iotexproject/iotex-proto

  2. Install grpcio-tools package pip install grpcio-tools

  3. Run following commands to generate code to python directory

mkdir python
python -m grpc_tools.protoc -I. -I ./proto/types --python_out=./python --grpc_python_out=./python ./proto/api/api.proto
python -m grpc_tools.protoc -I. -I ./proto/types --python_out=./python --grpc_python_out=./python ./proto/types/*

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

iotex-etl-1.0.2.tar.gz (44.4 kB view details)

Uploaded Source

File details

Details for the file iotex-etl-1.0.2.tar.gz.

File metadata

  • Download URL: iotex-etl-1.0.2.tar.gz
  • Upload date:
  • Size: 44.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/50.3.0 requests-toolbelt/0.9.1 tqdm/4.50.2 CPython/3.8.6

File hashes

Hashes for iotex-etl-1.0.2.tar.gz
Algorithm Hash digest
SHA256 66a867bec045c3e78a39ff4c9bf27ef48cc1e6bc147be097536d05077738abf6
MD5 9008b070daea337d1ec670827411c3e9
BLAKE2b-256 89a1c6cbb64c2bed084d1e543c57af09439040496a9395c9699396774ce0ac87

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