README ¶
Reserve Dollar
The Reserve Dollar (RSD) is a fiat-backed stablecoin from Reserve.
The Reserve Dollar is designed to maintain a stable price on the open market, by offering issuance and redemption of Reserve Dollars for fiat currency: 1 RSD per 1 USD.
The Reserve Dollar is not the Reserve or Reserve Share token described in the Reserve whitepaper. The whitepaper design is more fully decentralized, and more complicated. Rather, the Reserve Dollar is an initial stablecoin, suitable for building into products to test, being the first in a series of steps towards total decentralization, and to be an early-stage asset in the vault of the whitepaper design.
What does it do?
The Reserve Dollar offers normal ERC-20 behavior.
Reserve administers this token and offers issuance and redemption to verified users. Once a user has registered with our web portal (not in this repository) and entered information necessary for KYC/AML checks, the user will be eligible to buy and sell RSD for fiat currency. When a user buys RSD for fiat through our system, we mint RSD to give them; when a user sells RSD for fiat through our system, we burn those RSD.
To this end, Reserve controls external admin accounts. The admin accounts can mint and burn tokens to represent the on-chain side of these transactions. Various admin accounts can also freeze accounts, wipe long-frozen accounts, pause the token, upgrade the token, and update admin addresses.
How does it fit together?
There are three main smart contracts in contracts/
: ReserveDollar
, ReserveDollarEternalStorage
, and MintAndBurnAdmin
.
ReserveDollar
is the main token implementation. It provides ERC-20 and administration interfaces.ReserveDollarEternalStorage
is a static implementation of the Eternal Storage pattern forReserveDollar
. Any non-constant-sized data forReserveDollar
is stored there. However, because the token's storage is relatively simple, and the dynamic form of the EternalStorage pattern introduces difficulties in analysis,ReserveDollarEternalStorage
provides accessors for specific maps --balance
,allowed
, andfrozenTime
.MintAndBurnAdmin
is intended to hold theminter
role forReserveDollar
. We use this to give ourselves time to respond and recover in case our operational keys are stolen.
Environment Setup
To build and test everything in our configuration, your development environment will need:
- Go -- 1.12 or later, to run many tools: ABI generation, tests, coverage, our contract CLI.
- Node and NPM -- to run
sol-compiler
andsolium
- Docker -- to run echidna and 0x's a nicely-packaged
geth
node, for coverage and some end-to-end tests.
Setting up a clean environment
-
Install basic utilities for your system:
curl
,git
,make
,gcc
. -
Install Go
- Download the latest binary distribution
- Follow the installation instructions
- Check that the version is 1.12 or later with
go version
-
Install Node and npm
- Download from nodejs.org
- In this repo's working directory, do
npm install
to get local packages
-
Install Docker
Dockerized environment
There is also a dockerized version of our development environment on Docker Hub. If you have docker set up, you can open it with make run-dev-container
. It's not intended to handle all development workflows, but you should be able to successfully run make test
in it, and use it to troubleshoot your host environment if necessary. (That container is built from the Dockerfile in the root of this repository.)
Building and Testing
Quickstart
With an environment set up as above,
- To build and run unit tests:
make test
- To build smart contracts and their Go bindings:
make abi/bindings
- To compute coverage:
- In a separate long-lived terminal,
make run-geth
make coverage
(You will get a lot of warnings saying "We'll just skip that trace", even things are working right.)
- In a separate long-lived terminal,
- To deploy and interact with the smart contracts
- In a separate long-lived terminal,
make run-geth
make poke
poke --help
$(poke deploy)
- Interact using poke, e.g.:
poke changeMinter @1 poke mint --from @1 @2 123 poke balanceOf @2
- In a separate long-lived terminal,
Makefile
The root Makefile provides entry points for building and testing:
make fmt
: Use ethlint to lint and format smart contracts.make test
: Run tests for the smart contractsmake coverage
: Compute test coverage (where possible) for the smart contracts. Note that it has a few obvious false negatives, like the ReserveDollar constructor, interface definitions, and the_;
line in modifiers. Needs a localgeth
node listening atlocalhost:8545
; seemake run-geth
.make poke
: Build and install thepoke
CLI, for deploying and exercising with the Reserve Dollar smart contracts.poke
needs a localgeth
node listening atlocalhost:8545
; seemake run-geth
.make run-geth
: Run a local ethereum node suitable for testing and coverage.make run-dev-container
: Open dockerized development environment.
More on make run-geth
Some of our tools -- poke
and make coverage
-- expect to interact with a local geth node at http://localhost:8545
. Notably make test
does not require this; it uses a faster, in-memory EVM implementation.
The command make run-geth
sets up a local geth
node specialized for testing. make run-geth
will run the 0xorg/devnet
container and have it listen on port 8545. This command produces lots of live output to stdout, which is frequently useful. We recommend either running it in its own terminal, or at least piping its output somewhere so that you can tail -f
it.
Directory Layout
Highlights
contracts/
: The Reserve Dollar smart contractsReserveDollar.sol
: The main token implementation contract.ReserveDollarEternalStorage.sol
: Static implementation of the Eternal Storage pattern forReserveDollar
MintAndBurnAdmin.sol
: Contract intended to hold theminter
role forReserveDollar
.ReserveDollarV2.sol
: A tiny "upgraded" ReserveDollar contract, used here to test migration workflows.zepplin/SafeMath.sol
: The OpenZepplin SafeMath library.
tests/
: Unit tests for the Reserve Dollar smart contractscmd/poke/
A CLI for interacting with the Reserve Dollar smart contract.soltools/
: Go-to-JavaScript bridge, to wrap 0x's solidity tools.
The Rest
artifacts/
: Build destination for smart contractsabi/
: Build directory Go bindings for the smart contracts get built.README.md
: You're reading it.Makefile
: Entry points for building and testing, as above.Dockerfile
: Dockerfile for the dockerized dev environment- ... and a handful of other source-tree configuration files