Skip to main content

Static verifier for Vyper, based on Viper.

Project description

2vyper is an automatic verifier for smart contracts written in Vyper, based on the Viper verification infrastructure. It is being developed at the Programming Methodology Group at ETH Zurich. 2vyper was mainly developed by Robin Sierra, Christian Bräm, and Marco Eilers.

For examples of the provided specification constructs, check out the examples folder. Note that the examples are written in Vyper 0.1.0, but 2vyper supports different versions if a version pragma is set. A short overview of the most important specification constructs can be found here. For further documentation, read our paper about 2vyper’s specification constructs, Robin Sierra’s and Christian Bräm’s Master’s theses on the tool.

Dependencies (Ubuntu Linux, MacOS)

Install Java >= 11 (64 bit) and Python >= 3.7 (64 bit).

For usage with the Viper’s verification condition generation backend Carbon, you will also need to install the .NET / the Mono runtime.

Dependencies (Windows)

  1. Install Java >= 11 (64 bit) and Python >= 3.7 (64 bit).

  2. Install either Visual C++ Build Tools 2015 (http://go.microsoft.com/fwlink/?LinkId=691126) or Visual Studio 2015. For the latter, make sure to choose the option “Common Tools for Visual C++ 2015” in the setup (see https://blogs.msdn.microsoft.com/vcblog/2015/07/24/setup-changes-in-visual-studio-2015-affecting-c-developers/ for an explanation).

Getting Started

  1. Clone the 2vyper repository:

    git clone https://github.com/viperproject/2vyper
    cd 2vyper/
  2. Create a virtual environment and activate it:

    virtualenv env
    source env/bin/activate
  3. Install 2vyper:

    pip install .

Command Line Usage

To verify a specific file from the 2vyper directory, run:

2vyper [OPTIONS] path-to-file.vy

The following command line options are available:

``--verifier``
                Selects the Viper backend to use for verification.
                Possible options are ``silicon`` (for Symbolic Execution) and ``carbon``
                (for Verification Condition Generation based on Boogie).
                Default: ``silicon``.

``--viper-jar-path``
                Sets the path to the required Viper binaries (``silicon.jar`` or
                ``carbon.jar``). Only the binary for the selected backend is
                required. We recommend that you use the provided binary
                packages installed by default, but you can or compile your own from
                source.
                Expects either a single path or a colon- (Unix) or semicolon-
                (Windows) separated list of paths. Alternatively, the environment
                variables ``SILICONJAR``, ``CARBONJAR`` or ``VIPERJAR`` can be set.

``--z3``
                Sets the path of the Z3 executable. Alternatively, the
                ``Z3_EXE`` environment variable can be set.

``--boogie``
                Sets the path of the Boogie executable. Required if the Carbon backend
                is selected. Alternatively, the ``BOOGIE_EXE`` environment variable can be
                set.

``--counterexample``
                Produces a counterexample if the verification fails. Currently only works
                with the default ``silicon`` backend.

``--vyper-root``
                Sets the root directory for the Vyper compiler.

``--skip-vyper``
                Skips type checking the given Vyper program using the Vyper compiler.

``--print-viper``
                Print the generated Viper file to the command line.

To see all possible command line options, invoke 2vyper without arguments.

Alternative Viper Versions

To use a custom version of the Viper infrastructure, follow the instructions here. Look for sbt assembly to find instructions for packaging the required JAR files. Use the parameters mentioned above to instruct 2vyper to use your custom Viper version. Note that 2vyper may not always work with the most recent Viper version.

Troubleshooting

  1. On Windows: During the setup, you get an error like Microsoft Visual C++ 14.0 is required. or Unable to fnd vcvarsall.bat:

    Python cannot find the required Visual Studio 2015 C++ installation, make sure you have either installed the Build Tools or checked the “Common Tools” option in your regular VS 2015 installation (see above).

  2. While verifying a file, you get a stack trace ending with something like No matching overloads found:

    The version of Viper you’re using does not match your version of 2vyper. Try using the the one that comes with 2vyper instead.

Build Status

Build Status

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

2vyper-0.3.0.tar.gz (55.2 MB view details)

Uploaded Source

Built Distribution

2vyper-0.3.0-py3-none-any.whl (55.2 MB view details)

Uploaded Python 3

File details

Details for the file 2vyper-0.3.0.tar.gz.

File metadata

  • Download URL: 2vyper-0.3.0.tar.gz
  • Upload date:
  • Size: 55.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.10

File hashes

Hashes for 2vyper-0.3.0.tar.gz
Algorithm Hash digest
SHA256 b4e6d8470b457d43c192fffb66f7543790606ba651c6474a3d4033315c6d1bab
MD5 59469b32e0fe5d64dadd73db04416988
BLAKE2b-256 56180323d9e5d453766c76385e70a03f7cdadf37b776390c9841423baa301898

See more details on using hashes here.

File details

Details for the file 2vyper-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: 2vyper-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 55.2 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/46.4.0 requests-toolbelt/0.9.1 tqdm/4.46.0 CPython/3.7.10

File hashes

Hashes for 2vyper-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 059ef418589fafc1e881f868d6abdfa0a11ee192033e38c13cb6b49dca134f2b
MD5 d37513b311de797f23c02b10b781b192
BLAKE2b-256 521e724ee1a950d323e7e50910be541b7af0533edb0c37b8174e9dcea29fd9c3

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