Skip to main content

platon-hash: The Platon hashing function, keccak256, sometimes (erroneously) called sha3

Project description

platon-hash

Join the chat at https://gitter.im/platonnetwork/web3.py Build Status PyPI version Python versions Docs build

The Platon hashing function, keccak256, sometimes (erroneously) called sha3

Note: the similarly named pyethash has a completely different use: it generates proofs of work.

This is a low-level library, intended to be used internally by other Platon tools. If you're looking for a convenient hashing tool, check out platon_utils.keccak() which will be a little friendlier, and provide access to other helpful utilities.

Read more in the documentation on ReadTheDocs. View the change log.

Quickstart

pip install platon-hash[pycryptodome]
>>> from platon_hash.auto import keccak
>>> keccak(b'')
b"\xc5\xd2F\x01\x86\xf7#<\x92~}\xb2\xdc\xc7\x03\xc0\xe5\x00\xb6S\xca\x82';{\xfa\xd8\x04]\x85\xa4p"

See the docs for more about choosing and installing backends.

Developer Setup

If you would like to hack on platon-hash, please check out the Snake Charmers Tactical Manual for information on how we do:

  • Testing
  • Pull Requests
  • Code Style
  • Documentation

Development Environment Setup

You can set up your dev environment with:

git clone git@github.com:platonnetwork/platon-hash.git
cd platon-hash
virtualenv -p python3 venv
. venv/bin/activate
pip install -e .[dev]

Testing Setup

During development, you might like to have tests run on every file save.

Show flake8 errors on file change:

# Test flake8
when-changed -v -s -r -1 platon_hash/ tests/ -c "clear; flake8 platon_hash tests && echo 'flake8 success' || echo 'error'"

Run multi-process tests in one command, but without color:

# in the project root:
pytest --numprocesses=4 --looponfail --maxfail=1
# the same thing, succinctly:
pytest -n 4 -f --maxfail=1

Run in one thread, with color and desktop notifications:

cd venv
ptw --onfail "notify-send -t 5000 'Test failure' 'python 3 test on platon-hash failed'" ../tests ../platon_hash

Release setup

For Debian-like systems:

apt install pandoc

To release a new version:

make release bump=$$VERSION_PART_TO_BUMP$$

How to bumpversion

The version format for this repo is {major}.{minor}.{patch} for stable, and {major}.{minor}.{patch}-{stage}.{devnum} for unstable (stage can be alpha or beta).

To issue the next version in line, specify which part to bump, like make release bump=minor or make release bump=devnum. This is typically done from the master branch, except when releasing a beta (in which case the beta is released from master, and the previous stable branch is released from said branch).

If you are in a beta version, make release bump=stage will switch to a stable.

To issue an unstable version when the current version is stable, specify the new version explicitly, like make release bump="--new-version 4.0.0-alpha.1 devnum"

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

platon-hash-1.2.1.tar.gz (12.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

platon_hash-1.2.1-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

Details for the file platon-hash-1.2.1.tar.gz.

File metadata

  • Download URL: platon-hash-1.2.1.tar.gz
  • Upload date:
  • Size: 12.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.27.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.9.5

File hashes

Hashes for platon-hash-1.2.1.tar.gz
Algorithm Hash digest
SHA256 cdf2de5cabee39e9c152c7242e83d4523f8e743f48872a32a12c32c01c2858cd
MD5 c9e7485a7b8aecc095b9b549d2e9d209
BLAKE2b-256 150a1e9edc4cf980b9dca91d8d4af5dabdc076f64a218553886f17546b17c763

See more details on using hashes here.

File details

Details for the file platon_hash-1.2.1-py3-none-any.whl.

File metadata

  • Download URL: platon_hash-1.2.1-py3-none-any.whl
  • Upload date:
  • Size: 9.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.27.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.9.5

File hashes

Hashes for platon_hash-1.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4a52038dc132bccdea76e6933b1c496f201834be5ad09e98b990ea23eee3ec8e
MD5 c15b05a3471f8b7c03497ff1609cc649
BLAKE2b-256 242cbf7b78369e1908a05717e92b1aff024ac73e54a84d040c9082dee8eb993a

See more details on using hashes here.

Supported by

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