Skip to main content

A Zksync plugin for the Titanoboa Vyper interpreter

Project description

titanoboa-zksync

A Zksync plugin for the Titanoboa Vyper interpreter

Installation

First install the following dependencies, depending on your system:

Google Colab

For Google Colab: The following dependencies should be downloaded automatically.

Zkvyper Compiler

We use the era-compiler-vyper a.k.a. zkvyper: to compile Vyper code to ZkSync-compatible bytecode.

  1. Download the latest binary from the zkvyper-bin repository and rename it as zkvyper.

  2. On Linux/macOS, mark the binary as executable: chmod a+x <path to file>

  3. On macOS, the binary may need to have its quarantine attribute cleared: xattr -d com.apple.quarantine <path to file>

Then, make sure this is available in your system PATH.

ZkSync Node

If you want to test with forks or a local test node, you will need to install the ZkSync era-test-node.

  1. Download era-test-node from latest Release

  2. Extract the binary and mark as executable:

    tar xz -f era_test_node.tar.gz -C /usr/local/bin/
    chmod +x /usr/local/bin/era_test_node
    

Then, make sure this is available in your system PATH.

Install the plugin

Finally, install the package:

pip install git+https://github.com/DanielSchiavini/titanoboa-zksync.git@main

Usage

The usage of this plugin is similar to the original Titanoboa interpreter.

Configuring the environment

In Python:

import boa_zksync

boa_zksync.set_zksync_env("<rpc_url>")  # use RPC
boa_zksync.set_zksync_fork("<rpc_url>")  # fork from the mainnet
boa_zksync.set_zksync_test_env()  # run a local test node

In JupyterLab or Google Colab:

import boa, boa_zksync
from boa.integrations.jupyter import BrowserSigner

# use the browser signer and RPC:
boa_zksync.set_zksync_browser_env()  # use the browser signer and RPC
boa.env.set_chain_id(324)  # Set the chain ID to the ZkSync network

# use the browser signer and a custom RPC:
boa_zksync.set_zksync_env("<rpc_url>")
boa.env.set_eoa(BrowserSigner())

Interacting with the network

import boa, boa_zksync

constructor_args, address = [], "0x1234..."

boa_zksync.set_zksync_test_env()  # configure the environment, see previous section

# Compile a contract from source file
boa_zksync.ZksyncDeployer.create_compiler_data("source code")

# Load a contract from source code and deploy
boa.loads("contract source code", *constructor_args)

# Load a contract from file and deploy
contract = boa.load("path/to/contract.vy", *constructor_args)

# Load a contract from source file but don't deploy yet
deployer = boa.loads_partial("source code")
deployer.deploy(*constructor_args)  # Deploy the contract
deployer.at(address) # Connect a contract to an existing address

# Load a contract from source file but don't deploy yet
deployer = boa.loads_partial("source code")
deployer.deploy(*constructor_args)  # Deploy the contract
deployer.at(address) # Connect a contract to an existing address

# Run the given source code directly
boa.eval("source code")

Limitations

  • # pragma optimize gas is not supported by Zksync

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

titanoboa_zksync-0.1.2.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

titanoboa_zksync-0.1.2-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file titanoboa_zksync-0.1.2.tar.gz.

File metadata

  • Download URL: titanoboa_zksync-0.1.2.tar.gz
  • Upload date:
  • Size: 21.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.0 CPython/3.12.5

File hashes

Hashes for titanoboa_zksync-0.1.2.tar.gz
Algorithm Hash digest
SHA256 5a5b2a5e3a961e98afca609eddea788fa96ac80d39e3eb0c6a320e30e124138d
MD5 955295d22be2b8c9d22648ffcfe5b9b5
BLAKE2b-256 157f48c9c8dd3275d34c70cb6035c1b7077a5d7b275e18feda1c7a0fed6f82c1

See more details on using hashes here.

File details

Details for the file titanoboa_zksync-0.1.2-py3-none-any.whl.

File metadata

File hashes

Hashes for titanoboa_zksync-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f61687b3d72abc21aea4f6cf67d9e105c9bc40a8633f9cb90a5cf34ae15a23b8
MD5 54978c8d91573dc8ea84528d59ae6ba9
BLAKE2b-256 e8c86bb57fae4a3d4172478f00ea2a429431338402c5b351f512ab28c0e3e019

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