The CENTRE Fiat Token contract is an ERC-20 compatible token. It allows minting/burning of tokens by multiple entities, pausing all activity, freezing of individual addresses, and a way to upgrade the contract so that bugs can be fixed or features added.
The FiatToken
has a number of roles (addresses) which control different
functionality:
masterMinter
- adds and removes minters and increases their minting allowanceminters
- create and destroy tokenspauser
- pause the contract, which prevents all transfers, minting, and burningblacklister
- prevent all transfers to or from a particular address, and prevents that address from minting or burningowner
- re-assign any of the roles except foradmin
admin
- upgrade the contract, and re-assign itself
CENTRE will control the address of all roles except for minters, which will be controlled by the entities that CENTRE elects to make minters
The FiatToken
implements the standard methods of the ERC-20 interface with
some changes:
- A blacklisted address will be unable to call
transfer
,transferFrom
, orapprove
, and will be unable to receive tokens. transfer
,transferFrom
, andapprove
will fail if the contract has been paused.
The Fiat Token allows multiple entities to create and destroy tokens. These entities will have to be members of CENTRE, and will be vetted by CENTRE before they are allowed to create new tokens. CENTRE will not mint any tokens itself, it will approve members to mint and burn tokens.
Each minter
has a mintingAllowance
, which CENTRE configures. The
mintingAllowance
is how many tokens that minter may issue, and as a minter
issues tokens, its mintingAllowance
declines. CENTRE will periodically reset
the mintingAllowance
as long as a minter
remains in good standing with
CENTRE and maintains adequate reserves for the tokens it has issued. The
mintingAllowance
is to limit the damage if any particular minter
is
compromised.
CENTRE adds minters via the configureMinter
method. When a minter is
configured a mintingAllowance
is specified, which is the number of tokens that
address is allowed to mint. As a minter
mints tokens, the mintingAllowance
will decline.
- Only the
masterMinter
role may call configureMinter.
The minters
will need their allowance reset periodically to allow them to
continue minting. When a minter
's allowance is low, CENTRE can make another
call to configureMinter
to reset the mintingAllowance
to a higher value.
CENTRE removes minters via the removeMinter
method. This will remove the
minter
from the list of minters
and set its mintingAllowance
to 0. Once a
minter
is removed it will no longer be able to mint or burn tokens.
- Only the
masterMinter
role may callremoveMinter
.
A minter
mints tokens via the mint
method. The minter
specifies the
amount
of tokens to create, and a _to
address which will own the newly
created tokens. A minter
may only mint an amount less than or equal to its
mintingAllowance
. The mintingAllowance
will decrease by the amount of tokens
minted, and the balance of the _to
address and totalSupply
will each
increase by amount
.
-
Only a
minter
may callmint
. -
Minting fails when the contract is
paused
. -
Minting fails when the
minter
or_to
address is blacklisted. -
Minting emits a
Mint(minter, _to, amount)
event and aTransfer(0x00, _to, amount)
event.
A minter
burns tokens via the burn
method. The minter
specifies the
amount
of tokens to burn, and the minter
must have a balance
greater than
or equal to the amount
. Burning tokens is restricted to minter
addresses to
avoid accidental burning of tokens by end users. A minter
with a
mintingAllowance
of 0 is allowed to burn tokens. A minter
can only burn
tokens which it owns. When a minter burns tokens, its balance and the
totalSupply are reduced by amount
.
Burning tokens will not increase the mintingAllowance of the address doing the burning.
-
Only a minter may call burn.
-
Burning fails when the contract is paused.
-
Burning fails when the minter is blacklisted.
-
Burning emits a
Burn(minter, amount)
event, and aTransfer(minter, 0x00, amount)
event.
Addresses can be blacklisted. A blacklisted address will be unable to transfer tokens, approve, mint, or burn tokens.
CENTRE blacklists an address via the blacklist
method. The specified account
will be added to the blacklist.
- Only the
blacklister
role may callblacklist
. - Blacklisting emits a
Blacklist(account)
event
CENTRE removes an address from the blacklist via the unblacklist
method. The
specified account
will be removed from the blacklist.
- Only the
blacklister
role may callunblacklist
. - Unblacklisting emits an
UnBlacklist(account)
event.
The entire contract can be paused in case a serious bug is found or there is a serious key compromise. All transfers, minting, burning, and adding minters will be prevented while the contract is paused. Other functionality, such as modifying the blacklist, removing minters, changing roles, and upgrading will remain operational as those methods may be required to fix or mitigate the issue that caused CENTRE to pause the contract.
CENTRE will pause the contract via the pause
method. This method will set the
paused flag to true.
-
Only the
pauser
role may call pause. -
Pausing emits a
Pause()
event
CENTRE will unpause the contract via the unpause
method. This method will set
the paused
flag to false. All functionality will be restored when the contract
is unpaused.
-
Only the
pauser
role may call unpause. -
Unpausing emits an
Unpause()
event
The Fiat Token uses the zeppelinos Unstructured-Storage Proxy pattern
[https://docs.zeppelinos.org/docs/upgradeability_AdminUpgradeabilityProxy.html].
FiatTokenV1.sol is the implementation, the
actual token will be a Proxy contract
(FiatTokenProxy.sol) which will forward all
calls to FiatToken
via delegatecall. This pattern allows CENTRE to upgrade the
logic of any deployed tokens seamlessly.
- CENTRE will upgrade the token via a call to
upgradeTo
orupgradeToAndCall
if initialization is required for the new version. - Only the
admin
role may callupgradeTo
orupgradeToAndCall
.
The roles outlined above may be reassigned. The owner
role has the ability to
reassign all roles (including itself) except for the admin
role.
changeAdmin
updates theadmin
role to a new address.changeAdmin
may only be called by theadmin
role.
updateMasterMinter
updates themasterMinter
role to a new address.updateMasterMinter
may only be called by theowner
role.
updatePauser
updates thepauser
role to a new address.updatePauser
may only be called by theowner
role.
updateBlacklister
updates theblacklister
role to a new address.updateBlacklister
may only be called by theowner
role.
transferOwnership
updates theowner
role to a new address.transferOwnership
may only be called by theowner
role.