-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: capped minter v2 minter role #4
feat: capped minter v2 minter role #4
Conversation
7483d1f
to
f417601
Compare
d8da7d0
to
ca19636
Compare
bbaec92
to
31d626f
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks good some small comments
/// @notice Error for when the cap is exceeded. | ||
error ZkCappedMinterV2__CapExceeded(address minter, uint256 amount); | ||
|
||
/// @notice Error for when the caller is not the admin. | ||
/// @notice Error for when the account is unauthorized. | ||
error ZkCappedMinterV2__Unauthorized(address account); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can probably remove this error in favor of this one https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/IAccessControl.sol#L13
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
sounds good; see this reply for more context:
vm.prank(_cappedMinterAdmin); | ||
cappedMinter.grantRole(MINTER_ROLE, _minter); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
May be good to put this in a helper
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
function _revertIfUnauthorized() internal view { | ||
if (msg.sender != ADMIN) { | ||
if (!hasRole(MINTER_ROLE, msg.sender)) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We might want to use this instead. https://github.com/OpenZeppelin/openzeppelin-contracts/blob/master/contracts/access/AccessControl.sol#L86
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same in the upstream prs
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
also removed the Unauthorized
error since we are using _checkRole
; this version of oz uses string reverts, so the test checks accordingly.
will update in the subsequent pr's.
725dc00
to
1295f88
Compare
89702f0
to
af16880
Compare
af16880
to
007784b
Compare
l2-contracts/foundry.toml
Outdated
@@ -8,10 +9,10 @@ | |||
"@openzeppelin/contracts-upgradeable/=lib/openzeppelin-contracts-upgradeable/contracts/", | |||
"@openzeppelin/foundry-upgrades/=lib/openzeppelin-foundry-upgrades/src/", | |||
"@murky/=lib/murky/", | |||
"src/=src/", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this necessary?
l2-contracts/foundry.toml
Outdated
@@ -1,5 +1,6 @@ | |||
[profile.default] | |||
evm_version = "paris" | |||
fs_permissions = [{ access = "read", path = "./zkout" }] |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Also, why was this added?
12e615f
to
d0798f7
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
One comment looks good
l2-contracts/package.json
Outdated
"local-node": "npx hardhat node-zksync", | ||
"script": "node script/RunScript.js", | ||
"foundry-test": "forge test --no-match-path .integration.t.sol --zksync", | ||
"foundry-test": "forge test --match-path 'test/*.t.sol' --no-match-path 'test/*.integration.t.sol' --zksync", |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What is being excluded with this match-path? Is it necessary?
Description
Add
AccessControl
toZkCappedMinterV2
Kept all testing functionality the same as V1, but updated according to these changes. Also, included one more test for
testFuzz_RevertIf_AdminMintsByDefault