* 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 SignerRole is Context {
|
|
using Roles for Roles.Role;
|
|
|
|
event SignerAdded(address indexed account);
|
|
event SignerRemoved(address indexed account);
|
|
|
|
Roles.Role private _signers;
|
|
|
|
constructor () internal {
|
|
_addSigner(_msgSender());
|
|
}
|
|
|
|
modifier onlySigner() {
|
|
require(isSigner(_msgSender()), "SignerRole: caller does not have the Signer role");
|
|
_;
|
|
}
|
|
|
|
function isSigner(address account) public view returns (bool) {
|
|
return _signers.has(account);
|
|
}
|
|
|
|
function addSigner(address account) public onlySigner {
|
|
_addSigner(account);
|
|
}
|
|
|
|
function renounceSigner() public {
|
|
_removeSigner(_msgSender());
|
|
}
|
|
|
|
function _addSigner(address account) internal {
|
|
_signers.add(account);
|
|
emit SignerAdded(account);
|
|
}
|
|
|
|
function _removeSigner(address account) internal {
|
|
_signers.remove(account);
|
|
emit SignerRemoved(account);
|
|
}
|
|
}
|