View Source: contracts/core/token/NPM.sol
↗ Extends: WithPausability, WithRecovery, ERC20
NPM
Constants & Variables
uint256 private constant _CAP;
uint256 private _issued;
Events
event Minted(bytes32 indexed key, address indexed account, uint256 amount);
- constructor(address timelockOrOwner)
- _beforeTokenTransfer(address , address , uint256 )
- issue(bytes32 key, address mintTo, uint256 amount)
- issueMany(bytes32 key, address[] receivers, uint256[] amounts)
- transferMany(address[] receivers, uint256[] amounts)
- _issue(bytes32 key, address mintTo, uint256 amount)
function (address timelockOrOwner) public nonpayable Ownable Pausable ERC20
Arguments
Name | Type | Description |
---|---|---|
timelockOrOwner | address |
Source Code
constructor(address timelockOrOwner) Ownable() Pausable() ERC20("Neptune Mutual Token", "NPM") {
super._transferOwnership(timelockOrOwner);
}
function _beforeTokenTransfer(address , address , uint256 ) internal view whenNotPaused
Arguments
Name | Type | Description |
---|---|---|
address | ||
address | ||
uint256 |
Source Code
function _beforeTokenTransfer(
address,
address,
uint256
) internal view override whenNotPaused {
// solhint-disable-previous-line
}
function issue(bytes32 key, address mintTo, uint256 amount) external nonpayable onlyOwner whenNotPaused
Arguments
Name | Type | Description |
---|---|---|
key | bytes32 | |
mintTo | address | |
amount | uint256 |
Source Code
function issue(
bytes32 key,
address mintTo,
uint256 amount
) external onlyOwner whenNotPaused {
_issue(key, mintTo, amount);
}
function issueMany(bytes32 key, address[] receivers, uint256[] amounts) external nonpayable onlyOwner whenNotPaused
Arguments
Name | Type | Description |
---|---|---|
key | bytes32 | |
receivers | address[] | |
amounts | uint256[] |
Source Code
function issueMany(
bytes32 key,
address[] memory receivers,
uint256[] memory amounts
) external onlyOwner whenNotPaused {
require(receivers.length > 0, "No receiver");
require(receivers.length == amounts.length, "Invalid args");
for (uint256 i = 0; i < receivers.length; i++) {
_issue(key, receivers[i], amounts[i]);
}
}
function transferMany(address[] receivers, uint256[] amounts) external nonpayable onlyOwner whenNotPaused
Arguments
Name | Type | Description |
---|---|---|
receivers | address[] | |
amounts | uint256[] |
Source Code
function transferMany(address[] memory receivers, uint256[] memory amounts) external onlyOwner whenNotPaused {
require(receivers.length > 0, "No receiver");
require(receivers.length == amounts.length, "Invalid args");
for (uint256 i = 0; i < receivers.length; i++) {
super.transfer(receivers[i], amounts[i]);
}
}
function _issue(bytes32 key, address mintTo, uint256 amount) private nonpayable
Arguments
Name | Type | Description |
---|---|---|
key | bytes32 | |
mintTo | address | |
amount | uint256 |
Source Code
function _issue(
bytes32 key,
address mintTo,
uint256 amount
) private {
require(amount > 0, "Invalid amount");
super._mint(mintTo, amount);
_issued += amount;
require(_issued <= _CAP, "Cap exceeded");
emit Minted(key, mintTo, amount);
}
- AaveStrategy
- AccessControl
- AccessControlLibV1
- Address
- BaseLibV1
- BokkyPooBahsDateTimeLibrary
- BondPool
- BondPoolBase
- BondPoolLibV1
- CompoundStrategy
- console
- Context
- Cover
- CoverBase
- CoverLibV1
- CoverReassurance
- CoverStake
- CoverUtilV1
- cxToken
- cxTokenFactory
- cxTokenFactoryLibV1
- Delayable
- Destroyable
- ERC165
- ERC20
- FakeAaveLendingPool
- FakeCompoundDaiDelegator
- FakeRecoverable
- FakeStore
- FakeToken
- FakeUniswapPair
- FakeUniswapV2FactoryLike
- FakeUniswapV2PairLike
- FakeUniswapV2RouterLike
- FaultyAaveLendingPool
- FaultyCompoundDaiDelegator
- Finalization
- ForceEther
- Governance
- GovernanceUtilV1
- IAaveV2LendingPoolLike
- IAccessControl
- IBondPool
- IClaimsProcessor
- ICompoundERC20DelegatorLike
- ICover
- ICoverReassurance
- ICoverStake
- ICxToken
- ICxTokenFactory
- IERC165
- IERC20
- IERC20Detailed
- IERC20Metadata
- IERC3156FlashBorrower
- IERC3156FlashLender
- IFinalization
- IGovernance
- ILendingStrategy
- ILiquidityEngine
- IMember
- InvalidStrategy
- IPausable
- IPolicy
- IPolicyAdmin
- IPriceDiscovery
- IProtocol
- IRecoverable
- IReporter
- IResolution
- IResolvable
- IStakingPools
- IStore
- IStoreLike
- IUniswapV2FactoryLike
- IUniswapV2PairLike
- IUniswapV2RouterLike
- IUnstakable
- IVault
- IVaultDelegate
- IVaultFactory
- IWitness
- LiquidityEngine
- MaliciousToken
- MockAccessControlUser
- MockCoverUtilUser
- MockCxToken
- MockCxTokenPolicy
- MockCxTokenStore
- MockFlashBorrower
- MockProcessorStore
- MockProcessorStoreLib
- MockProtocol
- MockRegistryClient
- MockStore
- MockStoreKeyUtilUser
- MockValidationLibUser
- MockVault
- MockVaultLibUser
- NPM
- NPMDistributor
- NTransferUtilV2
- NTransferUtilV2Intermediate
- Ownable
- Pausable
- Policy
- PolicyAdmin
- PolicyHelperV1
- PoorMansERC20
- PriceDiscovery
- PriceLibV1
- Processor
- ProtoBase
- Protocol
- ProtoUtilV1
- Recoverable
- ReentrancyGuard
- RegistryLibV1
- Reporter
- Resolution
- Resolvable
- RoutineInvokerLibV1
- SafeERC20
- StakingPoolBase
- StakingPoolCoreLibV1
- StakingPoolInfo
- StakingPoolLibV1
- StakingPoolReward
- StakingPools
- Store
- StoreBase
- StoreKeyUtil
- StrategyLibV1
- Strings
- TimelockController
- Unstakable
- ValidationLibV1
- Vault
- VaultBase
- VaultDelegate
- VaultDelegateBase
- VaultDelegateWithFlashLoan
- VaultFactory
- VaultFactoryLibV1
- VaultLibV1
- VaultLiquidity
- VaultStrategy
- WithFlashLoan
- WithPausability
- WithRecovery
- Witness