forked from CMTA/CMTAT
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMintModule.sol
52 lines (43 loc) · 1.53 KB
/
MintModule.sol
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
//SPDX-License-Identifier: MPL-2.0
pragma solidity 0.8.17;
import "../../../../openzeppelin-contracts-upgradeable/contracts/token/ERC20/ERC20Upgradeable.sol";
import "../../../../openzeppelin-contracts-upgradeable/contracts/proxy/utils/Initializable.sol";
import "../../security/AuthorizationModule.sol";
abstract contract MintModule is ERC20Upgradeable, AuthorizationModule {
event Mint(address indexed beneficiary, uint256 amount);
function __MintModule_init(
string memory name_,
string memory symbol_,
address admin
) internal onlyInitializing {
/* OpenZeppelin */
__Context_init_unchained();
__ERC20_init_unchained(name_, symbol_);
// AccessControlUpgradeable inherits from ERC165Upgradeable
__ERC165_init_unchained();
// AuthorizationModule inherits from AccessControlUpgradeable
__AccessControl_init_unchained();
/* CMTAT modules */
// Security
__AuthorizationModule_init_unchained(admin);
// own function
__MintModule_init_unchained();
}
function __MintModule_init_unchained() internal onlyInitializing {
// no variable to initialize
}
/**
* @dev Creates `amount` new tokens for `to`.
*
* See {ERC20-_mint}.
*
* Requirements:
*
* - the caller must have the `MINTER_ROLE`.
*/
function mint(address to, uint256 amount) public onlyRole(MINTER_ROLE) {
_mint(to, amount);
emit Mint(to, amount);
}
uint256[50] private __gap;
}