Skip to main content

ape-foundry: Ape network provider for Foundry

Project description

ape-foundry

Foundry network provider plugin for Ape. Foundry is a development framework written in Node.js for Ethereum that includes a local network implementation.

Dependencies

  • python3 version 3.7 or greater, python3-dev
  • Foundry. See Foundry's Installation documentation for steps.

Installation

via pip

You can install the latest release via pip:

pip install ape-foundry

via setuptools

You can clone the repository and use setuptools for the most up-to-date version:

git clone https://github.com/ApeWorX/ape-foundry.git
cd ape-foundry
python3 setup.py install

Quick Usage

To use the plugin, first install Foundry locally into your Ape project directory:

cd your-ape-project
npm install --save-dev foundry

After that, you can use the --network ethereum:development:foundry command line flag to use the foundry network (if it's not already configured as the default).

This network provider takes additional Foundry-specific configuration options. To use them, add these configs in your project's ape-config.yaml:

foundry:
  port: 8555

To select a random port, use a value of "auto":

foundry:
  port: auto

This is useful for multiprocessing and starting up multiple providers.

Mainnet Fork

The ape-foundry plugin also includes a mainnet fork provider. It requires using another provider that has access to mainnet.

Use it in most commands like this:

ape console --network :mainnet-fork:foundry

Specify the upstream archive-data provider in your ape-config.yaml:

foundry:
  fork:
    ethereum:
      mainnet:
        upstream_provider: alchemy

Otherwise, it defaults to the default mainnet provider plugin. You can also specify a block_number.

NOTE: Make sure you have the upstream provider plugin installed for ape.

ape plugins install alchemy

Development

Please see the contributing guide to learn more how to contribute to this project. Comments, questions, criticisms and pull requests are welcomed.

License

This project is licensed under the Apache 2.0.

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

ape-foundry-0.2.0.tar.gz (23.1 kB view details)

Uploaded Source

Built Distribution

ape_foundry-0.2.0-py3-none-any.whl (12.9 kB view details)

Uploaded Python 3

File details

Details for the file ape-foundry-0.2.0.tar.gz.

File metadata

  • Download URL: ape-foundry-0.2.0.tar.gz
  • Upload date:
  • Size: 23.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/35.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.12

File hashes

Hashes for ape-foundry-0.2.0.tar.gz
Algorithm Hash digest
SHA256 416009e38272c38a668266385167bb40fbf227f4983372f036a3b18b7336c3e5
MD5 513abade43210c331ab39f4714bd3f05
BLAKE2b-256 32e188a4ce7976f1b4b199a64761d006a72a4da1fce3d969f41040aace78dfa3

See more details on using hashes here.

File details

Details for the file ape_foundry-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: ape_foundry-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 12.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/35.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.9 tqdm/4.64.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.12

File hashes

Hashes for ape_foundry-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8177b50234a2451175410a38f147e3fc51949e18a48f20b5065479b57dcedf30
MD5 1d567e93cb336e6d0455407d6a4f61f3
BLAKE2b-256 d582e034283c60e8f391bd78cb71825308b2f919c82db8fb4ced93c550f9a7a5

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