Python abstraction for ERC190 packages.
Project description
parse and validate packages
given a web3 instance provide access to contract factory classes
given a web3 instance provide access to all of the deployed contract instances for the chain that web3 is connected to.
validate package bytecode matches compilation output.
validate deployed bytecode matches compilation output
access to packages dependencies
construct new packages
Web3
The Package object will function much like the Contract class provided by web3. Rather than instantiating the base class provided by ethpm, you will instead use a classmethod which generates a new Package class for a given package.
OwnedPackage = BasePackage.factory('/path/to/owned-v1.0.0.json')
Then, the OwnedPackage can be instantiated with any web3 intance.
owned_package = OwnedPackage(web3)
A Package class can only be directly constructed from the parsed package JSON. It can also be initialized with the package’s URI or the local filesystem path to a package by using Package.from_file(path).
Contract Factories
Contract factories should be accessible from the package class but you must also provide a web3 instance.
Owned = OwnedPackage.get_contract_factory(web3, 'owned')
From a package instance, they are also available as properties.
Owned = owned_package.contract_factories.owned
In cases where a contract uses a library, the contract factory will have unlinked bytecode. The ethpm package ships with its own subclass of web3.contract.Contract with a few extra methods and properties related to bytecode linking
>>> math = owned_package.contract_factories.math
>>> math.has_linkable_bytecode
True
>>> math.is_bytecode_linked
False
>>> linked_math = math.link_bytecode({'MathLib': '0x1234...'})
>>> linked_math.is_bytecode_linked
True
Note: the actual format of the link data is not clear since library names aren’t a one-size-fits all solution. We need the ability to specify specific link references in the code.
Deployed Contracts
Deployed contracts are only available from package instances. The package instance will filter the deployments based on the chain that web3 is connected to.
Accessing deployments is done with property access
package.deployed_contracts.Greeter
IPFS
We’ll need a pluggable backend system for IPFS access. A built-in default one that defaults to using infura should be enough to get off the ground.
Lower priority but important will be ensuring that a user can configure connecting to their own IPFS node.
Verifying Things
The Package class should verify all of the following things.
Package json matches EthPM V2 Manifest Specification
Included bytecode matches compilation output
Deployed bytecode matches compilation output
Dependencies
The Package class should provide access to the full dependency tree.
>>> owned_package.build_dependencies['zeppelin']
<ZeppelinPackage>
Testing Strategy
Load and validate packages from disk.
Access package data.
Access contract factories.
EthPM-Spec
EthPM-Spec is referenced inside this repo as a submodule.**
If you clone this repository, you should run this command to fetch the contents of the submodule
git submodule init
Registry URI
The URI to lookup a package from a registry should follow the following format. (subject to change as the Registry Contract Standard makes it’s way through the EIP process)
scheme://authority/package-name?version=x.x.x
URI must be a string type
scheme: ercxxx
authority: Must be a valid ENS domain or a valid checksum address pointing towards a registry contract.
package-name: Must conform to the package-name as specified in the EthPM-Spec.
version: The URI escaped version string, should conform to the semver version numbering specification.
i.e. ercxxx://packages.zeppelinos.eth/owned?version=1.0.0
Release setup
For Debian-like systems:
apt install pandoc
To release a new version:
make release bump=$$VERSION_PART_TO_BUMP$$
How to bumpversion
The version format for this repo is {major}.{minor}.{patch} for stable, and {major}.{minor}.{patch}-{stage}.{devnum} for unstable (stage can be alpha or beta).
To issue the next version in line, specify which part to bump, like make release bump=minor or make release bump=devnum.
If you are in a beta version, make release bump=stage will switch to a stable.
To issue an unstable version when the current version is stable, specify the new version explicitly, like make release bump="--new-version 4.0.0-alpha.1 devnum"
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file ethpm-0.1.0a18.tar.gz
.
File metadata
- Download URL: ethpm-0.1.0a18.tar.gz
- Upload date:
- Size: 14.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 87be1885249ca1104d165f56f9982fc914736807909121568dd5d51054f37c13 |
|
MD5 | b79d6a02836f998cad648ff764fe2514 |
|
BLAKE2b-256 | 63ff2fc4473dd66bda7d9b23bb07c1855b8ef13e54e83f6e0f53d42d78345a8d |
File details
Details for the file ethpm-0.1.0a18-py3-none-any.whl
.
File metadata
- Download URL: ethpm-0.1.0a18-py3-none-any.whl
- Upload date:
- Size: 15.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bf5f292e7268a4f0d75cd5df72ee55ce4370c32d12f93941a9ed9319ef27d2db |
|
MD5 | 34c8d06b7ef4fa2a07b2fc461cb594f0 |
|
BLAKE2b-256 | 8a820b742a52b783153703d0f0cf851760933041336c70e067022fcc8910ddc1 |