Skip to main content

No project description provided

Project description


get in touch with ConsenSys Diligence
[ 🌐 📩 ]

Legions

EVM Node Security Toolkit

License: MIT CircleCI Code style: black PyPI

Legions is a handy toolkit for (security) researchers poking around EVM (Ethereum Virtual Machine) nodes and smart contracts, now with a slick command-line interface, with auto complete commands and history.

Features:

  • Node detection (getnodeinfo)
    • Detect the type of the Node, Chain, and Network
    • Peer Count, Listening, Synching, and Mining status
    • Gas Price
    • etc
  • Web3 API enumeration (investigate)
    • Accounts
      • Read coinbase, and exposed accounts of the node
      • (intrusive = True) will try to create accounts on the node
    • Admin
      • Enumerates web3.admin endpoints
    • Sign (WIP)
      • Enumerates signing functionalities (web3.sign)
  • ENS Queries (ens)
    • List Names owned by an address
    • List Subdomains of an address
    • Query individual names
  • Query at latest/specific block number (query)
    • Balance of an address
    • Block details
    • Bytecode of the smart contract
    • Read storage of the smart contract (default count=10 reads the first 10 slots)
    • command, which you can pass any RPC method with args
    • ECRecover of a signature
  • Conversions (toWei, fromWei, keccak, toChecksumAddress, etc)

This tool is in beta and a work in progress

Demo

Main Functionality

demo

ENS (Ethereum Name Service)

demo

Installation

Require Python 3.6.

pip install legions

Or directly from source code:

git clone https://github.com/shayanb/Legions
cd Legions
pip install .

Usage

If installed locally:

python legions.py

or if installed globally:

legions

Functions Breakdown

Command [Subcommand] Description
sethost Setup the Web3 connection (RPC, IPC, HTTP) (default to infura mainnet)
getnodeinfo Information about the connected node (run setnode before this)
conversions Conversions possible to do with Web3
fromWei Converts the input to ether (to currency default to ether)
toWei Converts the input to Wei (from currency default to ether)
keccak keccak hash of the input
toBytes Converts the input to hex representation of its Bytes
toChecksumAddress Converts the input to Checksum Address
toHex Converts the input text to Hex
fromWei Converts the input to ether (or specified currency)
query Query Blockchain (Storage, balance, etc)
balance Get Balance of an account
block Get block details by block number
code Get code of the smart contract at address
ecrecover Get address associated with the signature (ecrecover) BUGGY
storage Read the storage of a contract (count default = 10)
command Manual RPC method with args
investigate Investigate further in the node (e.g. check if accounts are unlocked, etc)
accounts Investigate accounts (e.g. check if accounts are unlocked, etc)
admin Investigate accounts (e.g. functionalities under the admin_ namespace)
sign Investigate signature functionalities
ens Do Ethereum Name Service queries (supported on the mainnet only)
toName Transform an address to the ENS name
toAddress Transform an ENS name to the Ethereum public address
info Get details about an ENS name
version Print Versions (If connected to a node it will print the host version too)

Acknowledgements

TODO:

  • eth 2.0 API implementation
  • Fix Verbose Status bar (It does not change from OFF)
  • inline TODOs (tons)
  • resolve mappings from storage (using ABI?)
  • Get tokens Balance (etherscan or other explorer API)

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

legions-0.8.4.tar.gz (19.5 kB view details)

Uploaded Source

Built Distributions

legions-0.8.4-py3.8.egg (36.7 kB view details)

Uploaded Source

legions-0.8.4-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

Details for the file legions-0.8.4.tar.gz.

File metadata

  • Download URL: legions-0.8.4.tar.gz
  • Upload date:
  • Size: 19.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/49.1.0 requests-toolbelt/0.8.0 tqdm/4.47.0 CPython/3.8.1

File hashes

Hashes for legions-0.8.4.tar.gz
Algorithm Hash digest
SHA256 a9a039476dcaf4ad62bf2e44c77554c6bd148b35bf38e73b125697f3a6eafdb4
MD5 d7395300fd20a2184a3c4688a78a0051
BLAKE2b-256 b06e7c03e06d4051730dad35e0acc0feeb17294bc49bbdcd298c041bf3364050

See more details on using hashes here.

File details

Details for the file legions-0.8.4-py3.8.egg.

File metadata

  • Download URL: legions-0.8.4-py3.8.egg
  • Upload date:
  • Size: 36.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.23.0 setuptools/49.1.0 requests-toolbelt/0.8.0 tqdm/4.47.0 CPython/3.8.1

File hashes

Hashes for legions-0.8.4-py3.8.egg
Algorithm Hash digest
SHA256 4d51b24afb2c60dcbb318a3c9d37c9e8764a0f1c82929f5c9eb81eb52d5c551e
MD5 4dd3d8b12a83b29a310ea35887de2fe2
BLAKE2b-256 b73c70760590bd867673960f8148e26966b46af1b9ec700244ffb40d71c12b3d

See more details on using hashes here.

File details

Details for the file legions-0.8.4-py3-none-any.whl.

File metadata

  • Download URL: legions-0.8.4-py3-none-any.whl
  • Upload date:
  • Size: 19.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/49.1.0 requests-toolbelt/0.9.1 tqdm/4.46.1 CPython/3.7.7

File hashes

Hashes for legions-0.8.4-py3-none-any.whl
Algorithm Hash digest
SHA256 8717c0c46c3dc4d357ab29c30af46a144dce58772302ec73859f8ad2fded978c
MD5 9c41ef46faf28cc73493b105909f85da
BLAKE2b-256 054f9e374d1d7bedfe2238b924ff7dee1af8634e810af4700bc30574339b4769

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