Skip to main content

Algorand Smart Contracts in Python

Project description

PyTeal logo

PyTeal: Algorand Smart Contracts in Python

Build Status PyPI version Documentation Status Code style: black

PyTeal is a Python language binding for Algorand Smart Contracts (ASC1s).

Algorand Smart Contracts are implemented using a new language that is stack-based, called Transaction Execution Approval Language (TEAL).

However, TEAL is essentially an assembly language. With PyTeal, developers can express smart contract logic purely using Python. PyTeal provides high level, functional programming style abstractions over TEAL and does type checking at construction time.

Install

PyTeal requires Python version >= 3.10.

If your operating system (OS) Python version < 3.10, we recommend:

  • Rather than override the OS Python version, install Python >= 3.10 alongside the OS Python version.
  • Use pyenv or similar tooling to manage multiple Python versions.

Recommended: Install from PyPi

Install the latest official release from PyPi:

  • pip install pyteal

Install Latest Commit

If needed, it's possible to install directly from the latest commit on master to use unreleased features:

WARNING: Unreleased code is experimental and may not be backwards compatible or function properly. Use extreme caution when installing PyTeal this way.

  • pip install git+https://github.com/algorand/pyteal

Documentation

Development Setup

Setup venv (one time):

  • python3 -m venv venv

Active venv:

  • . venv/bin/activate (if your shell is bash/zsh)
  • . venv/bin/activate.fish (if your shell is fish)

Pip install PyTeal in editable state with dependencies:

  • make setup-development
  • OR if you don't have make installed:
    • pip install -e . && pip install -r requirements.txt

Format code:

  • black .

Lint using flake8:

  • flake8 docs examples pyteal scripts tests *.py

Type checking using mypy:

  • mypy pyteal scripts

Run unit tests:

  • pytest pyteal tests/unit

Run integration tests (assumes a developer-mode algod is available on port 4001):

  • pytest tests/integration

Stand up developer-mode algod on ports 4001, 4002 and tealdbg on port 9392 (assumes Docker is available on your system):

  • docker-compose up -d

Tear down and clean up resources for the developer-mode algod stood up above:

  • docker-compose down

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

pyteal-0.26.1.tar.gz (250.8 kB view details)

Uploaded Source

Built Distribution

pyteal-0.26.1-py3-none-any.whl (318.9 kB view details)

Uploaded Python 3

File details

Details for the file pyteal-0.26.1.tar.gz.

File metadata

  • Download URL: pyteal-0.26.1.tar.gz
  • Upload date:
  • Size: 250.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for pyteal-0.26.1.tar.gz
Algorithm Hash digest
SHA256 11b43aabf99bef86101224e6397145d82aa2ebe4e2d74474912a9fadfb3e2696
MD5 6c1dc338bac131caa2d8080b9ae6b732
BLAKE2b-256 5fd67e16521a02c325268b8b52a58df9b933c90e6f3dcb85d5e33fd0e7e02ff1

See more details on using hashes here.

File details

Details for the file pyteal-0.26.1-py3-none-any.whl.

File metadata

  • Download URL: pyteal-0.26.1-py3-none-any.whl
  • Upload date:
  • Size: 318.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for pyteal-0.26.1-py3-none-any.whl
Algorithm Hash digest
SHA256 351ef6cff7ff930d20e8bbcb384305ba188005f30ae8d2ec32e07cf6c7e115fc
MD5 cd70a7d359faeb3434fc0d5f36d043c5
BLAKE2b-256 b25b4a66df0e522627a3ba6251ea6aa91777c9d424912edf3d990ea396f5aeaf

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