* switch to using Context internally
* add context import
* Add smoke test to make sure enabling GSN support works
* Update test/GSN/ERC721GSNRecipientMock.test.js
Co-Authored-By: Francisco Giordano <frangio.1@gmail.com>
* Upgrade truffle
* add missing awaits
* Revert "Upgrade truffle"
This reverts commit f9b0ba9019.
45 lines
1.0 KiB
Solidity
45 lines
1.0 KiB
Solidity
pragma solidity ^0.5.0;
|
|
|
|
import "../../GSN/Context.sol";
|
|
import "../Roles.sol";
|
|
|
|
contract CapperRole is Context {
|
|
using Roles for Roles.Role;
|
|
|
|
event CapperAdded(address indexed account);
|
|
event CapperRemoved(address indexed account);
|
|
|
|
Roles.Role private _cappers;
|
|
|
|
constructor () internal {
|
|
_addCapper(_msgSender());
|
|
}
|
|
|
|
modifier onlyCapper() {
|
|
require(isCapper(_msgSender()), "CapperRole: caller does not have the Capper role");
|
|
_;
|
|
}
|
|
|
|
function isCapper(address account) public view returns (bool) {
|
|
return _cappers.has(account);
|
|
}
|
|
|
|
function addCapper(address account) public onlyCapper {
|
|
_addCapper(account);
|
|
}
|
|
|
|
function renounceCapper() public {
|
|
_removeCapper(_msgSender());
|
|
}
|
|
|
|
function _addCapper(address account) internal {
|
|
_cappers.add(account);
|
|
emit CapperAdded(account);
|
|
}
|
|
|
|
function _removeCapper(address account) internal {
|
|
_cappers.remove(account);
|
|
emit CapperRemoved(account);
|
|
}
|
|
}
|