Pymaker
A Python API for the Maker Smart Contracts
Introduction
The Maker Protocol incentivizes external agents, called keepers, to automate certain operations around the Ethereum blockchain. In order to ease their development, an API around most of the Maker contracts has been created. It can be used not only by keepers, but may also be found useful by authors of some other, unrelated utilities aiming to interact with these contracts.
Based on the Pymaker API, a set of reference Maker keepers is being developed. They all used to reside in this repository, but now each of them has an individual one: bite-keeper (SCD only), arbitrage-keeper, auction-keeper (MCD only), cdp-keeper (SCD only), market-maker-keeper.
You only need to install this project directly if you want to build your own keepers, or if you want to play with this API library itself. If you just want to install one of reference keepers, go to one of the repositories linked above and start from there. Each of these keepers references some version of pymaker via a Git submodule.
Installation
This project uses Python 3.6.6.
In order to clone the project and install required third-party packages please execute:
git clone https://github.com/makerdao/pymaker.git
cd pymaker
pip3 install -r requirements.txtKnown Ubuntu issues
In order for the secp256k Python dependency to compile properly, following packages will need to be installed:
sudo apt-get install build-essential automake libtool pkg-config libffi-dev python-dev python-pip libsecp256k1-dev(for Ubuntu 18.04 Server)
Known macOS issues
In order for the Python requirements to install correctly on macOS, please install openssl, libtool, pkg-config and automake using Homebrew:
and set the LDFLAGS environment variable before you run pip3 install -r requirements.txt:
Available APIs
The current version provides APIs around:
ERC20Token,Tub,Tap,TopandVox(https://github.com/makerdao/sai),Vat,Cat,Vow,Jug,Flipper,Flapper,Flopper(https://github.com/makerdao/dss)SimpleMarket,ExpiringMarketandMatchingMarket(https://github.com/makerdao/maker-otc),TxManager(https://github.com/makerdao/tx-manager),DSGuard(https://github.com/dapphub/ds-guard),DSToken(https://github.com/dapphub/ds-token),DSEthToken(https://github.com/dapphub/ds-eth-token),DSValue(https://github.com/dapphub/ds-value),DSVault(https://github.com/dapphub/ds-vault),EtherDelta(https://github.com/etherdelta/etherdelta.github.io),0x v2Dai Savings Rate (Pot)(https://github.com/makerdao/pymaker/blob/master/tests/manual_test_dsr.py#L29)
APIs around the following functionality have not been implemented:
Global Settlement (End)Governance (DSAuth, DSChief, DSGuard, DSSpell, Mom)
Contributions from the community are much appreciated!
Code samples
Below you can find some code snippets demonstrating how the API can be used both for developing your own keepers and for creating some other utilities interacting with the Maker Protocol ecosystem contracts.
Token transfer
This snippet demonstrates how to transfer some SAI from our default address. The SAI token address is discovered by querying the Tub, so all we need as a Tub address:
Updating a DSValue
This snippet demonstrates how to update a DSValue with the ETH/USD rate pulled from CryptoCompare:
SAI introspection
This snippet demonstrates how to fetch data from Tub and Tap contracts:
Multi-collateral Dai
This snippet demonstrates how to create a CDP and draw Dai.
Asynchronous invocation of Ethereum transactions
This snippet demonstrates how multiple token transfers can be executed asynchronously:
Multiple invocations in one Ethereum transaction
This snippet demonstrates how multiple token transfers can be executed in one Ethereum transaction. A TxManager instance has to be deployed and owned by the caller.
Ad-hoc increasing of gas price for asynchronous transactions
Testing
Prerequisites:
ganache-cli 6.2.5 (using npm,
sudo npm install -g [email protected])
This project uses pytest for unit testing. Testing of Multi-collateral Dai is performed on a Dockerized local testchain included in tests\config.
In order to be able to run tests, please install development dependencies first by executing:
You can then run all tests with:
If you have questions regarding Pymaker, please reach out to us on the #keeper channel on chat.makerdao.com.
Last updated