Giter VIP home page Giter VIP logo

pyteal's Introduction

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

pyteal's People

Contributors

jasonpaulos avatar stechu avatar tzaffi avatar ahangsu avatar barnjamin avatar michaeldiamant avatar algochoi avatar algoidurovic avatar bbroder-algo avatar fabrice102 avatar ciottigiorgio avatar ursify avatar shiqizng avatar stylishtriangles avatar algojack avatar ipaleka avatar winder avatar shyba avatar thadguidry avatar shaih avatar pablolion avatar moataz-e avatar lvorithm avatar krotkiewicz avatar onetechnical avatar joe-p avatar jdtzmn avatar eltociear avatar hernandp avatar hashmapsdata2value avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.