NMR Ethereum Smart Contract
Numeraire (NMR) is an ERC-20 token used for staking and burning.
NMR is the native token of the Erasure Protocol.
See documentation for more information.
Security Contact: email@example.com
|NMR Token||New Alchemy||May 2017|
|NMR Code Fix||New Alchemy||April 2018|
|NMR 2.0||Trail of Bits||July 2019|
|Numerai||Richard Craib, Geoffrey Bradway, Xander Dunn, Joey Krug||February 2017|
|Erasure Quant||Richard Craib, James Geary, Jason Paryani||August 2019|
|Erasure Bay||Stephane Gosselin, Jonathan Sidego||March 2020|
function approve(address _spender, uint256 _value); function transfer(address _to, uint256 _value); function transferFrom(address _from, address _to, uint256 _value); function totalSupply(); function balanceOf(address _owner); function allowance(address _owner, address _spender); event Transfer(address indexed _from, address indexed _to, uint256 _value); event Approval(address indexed _owner, address indexed _spender, uint256 _value);
Refer to ERC-20 standard for detailed specification.
Note: NMR deviates from ERC-20 in the implementation of the
approve() function to prevent the ERC-20 approve race condition.
approve() function is limited to changing the allowance from zero or to zero.
In order to change the allowance from a non-zero value to a different non-zero value in a single transaction. The user must use the
function changeApproval(address _spender, uint256 _oldValue, uint256 _newValue);
Sets the approval to a new value while checking that the previous approval value is what we expected.
_spenderis the address of the contract.
_oldValueis the current amount the contract is allowed to spend.
_newValueis the new amount to allow the contract to spend.
numeraiTransfer() functions have been repurposed from their initial use in order to support native token burns as implemented in OpenZeppelin's ERC20Burnable.
Note: The caller must check the return values of these functions as they return false on failure.
/** * @dev Destoys `amount` tokens from `msg.sender`, reducing the total supply. * * Emits a `Transfer` event with `to` set to the zero address. * * Requirements: * - `account` must have at least `amount` tokens. */ function mint(uint256 _value); => function burn(uint256 amount); /** * @dev Destoys `amount` tokens from `account`.`amount` is then deducted * from the caller's allowance. * * Emits an `Approval` event indicating the updated allowance. * Emits a `Transfer` event with `to` set to the zero address. * * Requirements: * - `account` must have at least `amount` tokens. * - `account` must have approved `msg.sender` with allowance of at least `amount` tokens. */ function numeraiTransfer(address _to, uint256 _value); => function burnFrom(address account, uint256 amount);
Custody for Numerai Tournament
Numerai performs custody of the token for participants in the Numerai Tournament. This removes participation barriers as users no longer need to pay for gas or manage their own private keys. The
withdraw() function can be used by Numerai to transfer tokens from the first 1 million accounts (0x00...00000000 to 0x00...000F4240).
function withdraw(address _from, address _to, uint256 _value);
All other contract methods belong to the following features which have been disabled as a part of the NMR 2.0 upgrade.
- Emergency Stops